将Aria-labels添加到Angular分页网格中以使其更易于访问

Ili*_*ani 6 pagination accessibility screen-readers angularjs

在我从这个线程中借用的这个plunker示例中,有一个很棒的示例,说明如何使用AngularJs创建分页网格.(我的问题与这个类似的问题略有不同.)

在我们的一个项目中,我们有一个非常相似的解决方案,但为了获得一些帮助,我将使用上面提到的plunker中的代码.

我的目标:我想让屏幕阅读器更容易访问底部的分页网格这是通过在网格的按钮上添加一些咏叹调标签来完成的,例如

aria-label="Go to first page"
aria-label="Go to previous page"
aria-label="Go to page 3"
Run Code Online (Sandbox Code Playgroud)

等等.我该如何做到这一点?

最后,这是代码:

模板:

<!DOCTYPE html>
<html ng-app="todos">

  <head>
   <link data-require="bootstrap-css@*" data-semver="3.3.1" rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.1/css/bootstrap.min.css" />
    <script data-require="angular.js@*" data-semver="1.3.15" src="https://code.angularjs.org/1.3.15/angular.js"></script>
    <script data-require="ui-bootstrap@*" data-semver="0.12.1" src="http://angular-ui.github.io/bootstrap/ui-bootstrap-tpls-0.12.1.min.js">    </script>
    <link rel="stylesheet" href="style.css" />
    <script src="script.js"></script>
  </head>

  <body ng-controller="TodoController">
    <h1>Todos</h1>
    <h4>{{todos.length}} total</h4>
    <ul>
      <li ng-repeat="todo in filteredTodos">{{todo.text}}</li>
    </ul>
    <pagination 
      ng-model="currentPage"
      total-items="todos.length"
      max-size="maxSize"  
      boundary-links="true">
    </pagination>
  </body>
</html>
Run Code Online (Sandbox Code Playgroud)

控制器:

var todos = angular.module('todos', ['ui.bootstrap']);

todos.controller('TodoController', function($scope) {
   $scope.filteredTodos = []
  ,$scope.currentPage = 1
  ,$scope.numPerPage = 10
  ,$scope.maxSize = 5;

  $scope.makeTodos = function() {
    $scope.todos = [];
    for (i=1;i<=1000;i++) {
      $scope.todos.push({ text:'todo '+i, done:false});
    }
  };
  $scope.makeTodos(); 

  $scope.$watch('currentPage + numPerPage', function() {
    var begin = (($scope.currentPage - 1) * $scope.numPerPage)
    , end = begin + $scope.numPerPage;

    $scope.filteredTodos = $scope.todos.slice(begin, end);
  });
});
Run Code Online (Sandbox Code Playgroud)

slu*_*ous 3

首先,让我先说一下我从未使用过或看过 Angular。你有自己的 Angular 副本吗?只是浏览了一下,分页元素似乎是从template/pagination/pagination.html中的模板生成的。当我查看该来源时,它有类似的内容

<li role="menuitem" ng-if="::directionLinks" ng-class="{disabled: noNext()||ngDisabled}" class="pagination-next">
   <a href ng-click="selectPage(page + 1, $event)" ng-disabled="noNext()||ngDisabled" uib-tabindex-toggle>{{::getText('next')}}
   </a>
</li>
Run Code Online (Sandbox Code Playgroud)

可以修改模板吗?如果是这样,您可以向 中添加一个 aria-label <a>,甚至可以以相同的方式从 paginationConfig 获取其文本。

我通过查看你的 plunker 示例中的ui-bootstrap-tpls-0.12.1.min.js发现了这一点。