angularjs - 将 Aria 标签添加到 Angular 分页网格以使其更易于访问

标签 angularjs pagination accessibility screen-readers

this plunker example我借用this thread ,有一个很棒的示例说明如何使用 AngularJs 创建分页网格。 (我的问题与 this similar question 有点不同。)

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

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

aria-label="Go to first page"
aria-label="Go to previous page"
aria-label="Go to page 3"

等等。我该如何实现这一目标?

最后,这是代码:

模板:

<!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>

Controller :

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);
  });
});

最佳答案

首先,让我先说一下我从未使用过或看过 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>

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

我通过四处浏览发现了这个ui-bootstrap-tpls-0.12.1.min.js从你的笨蛋例子中。

关于angularjs - 将 Aria 标签添加到 Angular 分页网格以使其更易于访问,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39244129/

相关文章:

javascript - 当具有渲染器的 DOM 元素不在屏幕顶部时移动场景的坐标

带分页处理的 Golang 网络蜘蛛

javascript - jQuery 分页插件事件目标

html - 辅助功能:如何为一个 INPUT 项正确使用多个 LABEL 元素(通过 ARIA 等)?

ios - 如何覆盖自定义 UIButton 的 VoiceOver 光标矩形?

javascript - 具有嵌套属性的 ng-class

javascript - AngularJs:ng-if react 太迟

angularjs - 如何使 textangulars 插入 html 允许使用 iframe

jquery - 分页 JS 停止工作,我不知道为什么

ios - iOS 特殊字符的辅助功能