Dal 1.4.0 angolare, il limitTo
filter prende un argomento opzionale begin
:
<div ng-repeat="item in items | limitTo:5:5">{{item}}</div>
Nelle versioni più vecchie, la scrittura di un filtro personalizzato è abbastanza semplice. Ecco un'implementazione ingenuo sulla base di Array#slice
(nota si passa il primo e l'ultimo indice, invece di un conteggio):
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>
lavoro jsFiddle: http://jsfiddle.net/BinaryMuse/vQUsS/
In alternativa, si può semplicemente rubare 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);
}
}
};
}
fonte
2013-02-10 09:09:33
@ risposta bluescreen qui sotto (con 20 voti in su) è la risposta corretta qui. Si prega di scegliere quello. – RavenHursT
continuava a darmi errori su arr essendo indefinito così ho fatto questo arr = arr || []; return arr.slice (start, end); –
Non riesco a farcela con la notazione 'ControllerAs': http://jsfiddle.net/r9kvaydh/3/ –