我怎样才能重复显示接下来的15个项目

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

本文关键字:接下来 显示 15个 项目      更新时间:2023-09-26

我目前正在使用angular ng repeat。

当用户点击一个写着"下一个15"的按钮时,我想显示下一个的15个项目。我不想从数组中弹出项目,我只想隐藏前15个,并将显示限制在后15个。

此外,当用户点击"上一个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