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

时间:2015-04-05 14:11:41

标签: javascript angularjs angularjs-scope angularjs-ng-repeat angular-ui

我目前正在使用角度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;
    };
});

2 个答案:

答案 0 :(得分:7)

你去了 - 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>

答案 1 :(得分:0)

以下内容将使您的视图保持整洁且逻辑可测试:

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