如何在用户完成输入时调用angularjs ngChange处理程序

9bl*_*lue 49 angularjs angularjs-ng-change angular-ngmodel

我有一个input字段,我想在其中应用变体ngChange.

input字段与ajax调用绑定,当用户更改输入时,服务器端将处理数据,但是,我不想经常拨打电话.

假设用户想输入一个真正的字符串,我希望只有在用户完成他要输入的单词后才能进行调用.不过,我不想使用模糊等事件.什么是更好的方法来实现这一点,而不是setTimeout

cal*_*oyd 105

ng-model-options在Angular中使用> 1.3

 <input type="text"
         ng-model="vm.searchTerm"
         ng-change="vm.search(vm.searchTerm)"
         ng-model-options="{debounce: 750}" />
Run Code Online (Sandbox Code Playgroud)

没有ng-model-options- 在标记中:

<input ng-change="inputChanged()">
Run Code Online (Sandbox Code Playgroud)

在您的支持控制器/范围

var inputChangedPromise;
$scope.inputChanged = function(){
    if(inputChangedPromise){
        $timeout.cancel(inputChangedPromise);
    }
    inputChangedPromise = $timeout(taskToDo,1000);
}
Run Code Online (Sandbox Code Playgroud)

然后你的taskToDo意志只会在1000毫秒没有变化后运行.

  • 我爱你...真实的<3 (2认同)

Adr*_*ien 38

从Angular 1.3开始,您可以使用Angular ng-model-options指令

<input ng-change="inputChanged()" ng-model-options="{debounce:1000}">
Run Code Online (Sandbox Code Playgroud)

资料来源:https://stackoverflow.com/a/26356084/1397994