如何在 ng-repeat 中显示接下来的 15 个项目?

How can I show next 15 items in ng-repeat?

我目前正在使用 angular ng-repeat。

当用户单击显示 "Next 15" 的按钮时,我想显示接下来的 15 个项目。 我不想从数组中弹出项目,我只想隐藏前 15 个,并将显示限制为仅显示接下来的 15 个。

此外,当用户点击 "Prev 15" 时,我想只显示前 15 个项目。

这是我目前的情况:

HTML:

<div ng-controller="ctrlIndex as vm">


    <ul ng-repeat=" item in vm.items | limitTo: 15 * vm.page
                                 | limitTo: 15 * vm.page < count ? limitTo: 15 * vm.page : 15 - (15 * vm.page - count)"/>
        <li>{{ item }}</li>
    </ul>
<div><button ng-click="vm.next()">Next 15</button></div>
<div><button ng-click="vm.back()">Prev 15</button></div>

Javascript:

 var app = angular.module('app', []);

 3app.controller('ctrlIndex', function(){

    var vm = this;
    vm.numRecords = 15;
    vm.page = 1;

    vm.items = []
    for (var i = 0; i < 1000000; ++i) {
        vm.items.push('item : ' + i);
    }

    vm.next = function(){
        vm.page = vm.page + 1;
    };

    vm.back = function(){
        vm.page = vm.page - 1;
    };
});

给你 - Plunker

标记

<body ng-app="app">
    <div ng-controller="ctrlIndex as vm">
        <ul ng-repeat="item in vm.items track by $index"
      ng-show="(($index < (vm.page * vm.numRecords)) && ($index >= ((vm.page - 1) * vm.numRecords)))">
            <li>{{ item }}</li>
        </ul>

        <div><button ng-click="vm.next()">Next 15</button></div>
        <div><button ng-click="vm.back()">Prev 15</button></div>
    </div>
</body>

像下面这样的东西可以让你保持你的视图整洁和你的逻辑可测试:

   // controller
   var vm = this;
   vm.numRecords = 15;
   vm.page = 0;
   vm.items = [];
   vm.data = {};
   vm.data.shownItems = [];
   vm.limit = 100;
   vm.maxPages = Math.floor(vm.limit / vm.numRecords);

   for (var i = 0; i < vm.limit; ++i) {
     vm.items.push('item : ' + i);
   }

   vm.data.shownItems = vm.items.slice(0, this.numRecords);

   vm.next = function() {
     if (vm.page >= vm.maxPages) {
       return
     }
     vm.page += 1;
     var begin = vm.page * vm.numRecords;
     var end = begin + vm.numRecords;
     vm.data.shownItems = vm.items.slice(begin, end);
   };

   vm.back = function() {
     if (vm.page <= 0) {
       return
     }
     vm.page -= 1;
     var begin = vm.page * vm.numRecords;
     var end = begin + vm.numRecords;
     vm.data.shownItems = vm.items.slice(begin, end);
   };

// view
<ul ng-repeat="item in vm.data.shownItems">
    <li>{{ item }}</li>
</ul>

Plunker