Ich versuche, nächste und vorherige Schaltfläche in eckigen zu erstellen. Ich bin neu in der Programmierung. Ich habe ein Programm geschrieben. Wenn ich benutzerdefinierte Array $scope.data = []
verwenden, funktioniert es. Wenn ich $http
benutze es funktioniert nicht bitte helfen, dies zu lösen.Angularjs nächste und vorherige Schaltfläche?
Controller.js
var app=angular.module('myApp', []);
app.controller('MyCtrl', ['$scope', '$http', '$filter', function ($scope, $filter, $http) {
$scope.currentPage = 0;
$scope.pageSize = 2;
$scope.numberOfPages=function(){
return Math.ceil($scope.pageSize);
}
/*$scope.data = [
{ title: 'Reggae', id: 1 },
{ title: 'Chill', id: 2 },
{ title: 'Dubstep', id: 3 },
{ title: 'Indie', id: 4 },
{ title: 'Rap', id: 5 },
{ title: 'Cowbell', id: 6 }
];*/
$http.get('https://raw.githubusercontent.com/bantic/imdb-data-scraping/master/data/movies.json')
.then(function(response){
$scope.data = response.data;
});
}]);
app.filter('startFrom', function() {
return function(input, start) {
start = +start; //parse to int
return input.slice(start);
}
});
index.htlm
<div ng-app="myApp" ng-controller="MyCtrl">
<ul>
<li ng-repeat="item in data | startFrom:currentPage*pageSize | limitTo:pageSize">
{{item.title}}
</li>
</ul>
<button ng-disabled="currentPage == 0" ng-click="currentPage=currentPage-1">
Previous
</button>
{{currentPage+1}}/{{numberOfPages()}}
<button ng-disabled="currentPage >= getData().length/pageSize - 1" ng-click="currentPage=currentPage+1">
Next
</button>
</div>
Ausgabe
Previous {{currentPage+1}}/{{numberOfPages()}} Next
Ich bin neu in der Programmierung, damit ich verstehen kann. – joydee
@joydee akzeptieren die Antwort, indem Sie direkt unter der Anzahl der Upvotes klicken, THanks –