AngularJS 1.3 이상
AngularJS 1.3부터는 전혀 사용하지 않고도 매우 쉽게 얻을 수있는 debounce
속성을 활용할 수 있습니다 . 예를 들면 다음과 같습니다.ngModelOptions
$timeout
HTML :
<div ng-app='app' ng-controller='Ctrl'>
<input type='text' placeholder='Type a name..'
ng-model='vm.name'
ng-model-options='{ debounce: 1000 }'
ng-change='vm.greet()'
/>
<p ng-bind='vm.greeting'></p>
</div>
JS :
angular.module('app', [])
.controller('Ctrl', [
'$scope',
'$log',
function($scope, $log){
var vm = $scope.vm = {};
vm.name = '';
vm.greeting = '';
vm.greet = function greet(){
vm.greeting = vm.name ? 'Hey, ' + vm.name + '!' : '';
$log.info(vm.greeting);
};
}
]);
-또는-
바이올린 확인
AngularJS 1.3 이전
지연을 추가하려면 $ timeout을 사용해야하며 $ timeout.cancel (previoustimeout)을 사용하면 이전 제한 시간을 취소하고 새 제한 시간을 실행할 수 있습니다 (필터링이 한 시간 내에 여러 번 연속적으로 실행되는 것을 방지하는 데 도움이됩니다. 시간 간격)
예를 들면 다음과 같습니다.
app.controller('MainCtrl', function($scope, $timeout) {
var _timeout;
//...
//...
$scope.FilterByName = function() {
if(_timeout) { // if there is already a timeout in process cancel it
$timeout.cancel(_timeout);
}
_timeout = $timeout(function() {
console.log('filtering');
_timeout = null;
}, 500);
}
});
$timeout
500ms 동안 a 를 사용하십시오 .$scope.FilterByName = function () { $timeout(_filterByName , 500)