Próbuję utworzyć prostą dyrektywę paginacji z izolowanym zasięgiem. Z jakiegoś powodu, kiedy ręcznie zmieniam wartość, uzyskuje się odrobinę finnicky. Oto mój problem:Wejście AngularJS nie aktualizuje modelu
Kiedy strona naprzód i wstecz, działa świetnie. Awesome
Kiedy wchodzę na stronę do pola, to działa. Great
Jeśli jednak wprowadzę stronę do pola, a następnie spróbuję przejść do przodu i do tyłu, model ng wydaje się łamać po wprowadzeniu strony do pola. Miałem to działa, gdy nie izolowałem mojego zakresu, ale jestem zdezorientowany, dlaczego go złamać. Tu jest mój kodu:
HTML:
<paginate go-to-page="goToPage(page)" total-pages="results.hits.pages" total-hits="results.hits.total"></paginate>
dyrektywa:
'use strict';
angular.module('facet.directives')
.directive('paginate', function(){
return {
restrict: 'E',
template: '<div class="pull-right" ng-if="(totalPages !== undefined) && (totalPages > 0)">'+
'<span class="left-caret hoverable" ng-click="changePage(current-1)" ng-show="current > 1"></span> Page'+
' <input type="number" ng-model="current" class="pagination-input" ng-keypress="enterPage($event)"/> of'+
' {{totalPages}} '+
'<span class="right-caret hoverable" ng-click="changePage(current+1)" ng-show="current < totalPages"></span>'+
'</div>',
scope: {
goToPage: '&',
totalPages: '=',
totalHits: '='
},
link: function(scope) {
scope.current = 1;
scope.changePage = function(page) {
scope.current = page;
window.scrollTo(0,0);
scope.goToPage({page:page});
};
scope.enterPage = function(event) {
if(event.keyCode == 13) {
scope.changePage(scope.current);
}
}
}
}
});
Co robię źle?
można skonfigurować jsFiddle lub Plunkr? –