angularjs - 在 AngularJS 中使用 ng-repeat 过滤结果 6 到 10(共 100 个)

标签 angularjs

我在文档中看到 limitTo 过滤器,它允许我限制前 5 个或后 5 个结果,但我想设置限制的开始位置,以便我可以显示第二组结果5 个结果。

是否有内置过滤器?

最佳答案

自 Angular 1.4.0 起,limitTo filter采用可选的 begin 参数:

<div ng-repeat="item in items | limitTo:5:5">{{item}}</div>

在旧版本中,编写自定义过滤器相当简单。这是基于 Array#slice 的简单实现(请注意,您传递的是第一个和最后一个索引,而不是计数):

app.filter('slice', function() {
  return function(arr, start, end) {
    return (arr || []).slice(start, end);
  };
});
<div ng-repeat="item in items | slice:6:10">{{item}}</div>

工作中的 jsFiddle: http://jsfiddle.net/BinaryMuse/vQUsS/

或者,您可以简单地窃取 the entire Angular 1.4.0 implementation of limitTo :

function limitToFilter() {
  return function(input, limit, begin) {
    if (Math.abs(Number(limit)) === Infinity) {
      limit = Number(limit);
    } else {
      limit = toInt(limit);
    }
    if (isNaN(limit)) return input;

    if (isNumber(input)) input = input.toString();
    if (!isArray(input) && !isString(input)) return input;

    begin = (!begin || isNaN(begin)) ? 0 : toInt(begin);
    begin = (begin < 0 && begin >= -input.length) ? input.length + begin : begin;

    if (limit >= 0) {
      return input.slice(begin, begin + limit);
    } else {
      if (begin === 0) {
        return input.slice(limit, input.length);
      } else {
        return input.slice(Math.max(0, begin + limit), begin);
      }
    }
  };
}

关于angularjs - 在 AngularJS 中使用 ng-repeat 过滤结果 6 到 10(共 100 个),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14796087/

相关文章:

javascript - angularjs - 如何在 sessionStorage 中存储数组?

javascript - 如何更改自定义 Angular 指令中的 ng-model 范围值?

javascript - 将变量从 Node/Express 传递到 AngularJS

angularjs - 使用 ng-repeat 时无法居中对齐文本

angularjs - 在 Protractor 中动态加载 ngMock httpBackend 响应的 JSON

javascript - Angularjs 路由与 Backbonejs 路由

angularjs - 如何获取从 Angular 到 NodeJS/Express JS 的多个 GET 请求参数

javascript - 如何让我的脚本在 AngularJS 中的文本框输入更改上执行?

JavaScript 单元测试 : Cannot check if jQuery method was called

javascript - 在探索 Angular2 之前是否有必要先学习 TypeScript?