微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Angularjs:input [text] ngChange在值改变时触发

ngChange在值改变时触发(ngChange与经典的onChange事件不相似)。我如何绑定经典的onChange事件与angularjs,只会在内容提交时触发?

当前绑定:

<input type="text" ng-model="name" ng-change="update()" />
This post显示一个指令的示例,它将模型更改延迟到输入,直到 blur事件触发。

Here一个小调,显示ng变化使用新的ng模型模糊指令。注意这是一个轻微的调整到original fiddle

如果你添加指令到你的代码,你会将你的绑定更改为:

<input type="text" ng-model="name" ng-model-onblur ng-change="update()" />

这里是指令:

// override the default input to update on blur
angular.module('app',[]).directive('ngModelOnblur',function() {
    return {
        restrict: 'A',require: 'ngModel',priority: 1,// needed for angular 1.2.x
        link: function(scope,elm,attr,ngModelCtrl) {
            if (attr.type === 'radio' || attr.type === 'checkBox') return;

            elm.unbind('input').unbind('keydown').unbind('change');
            elm.bind('blur',function() {
                scope.$apply(function() {
                    ngModelCtrl.$setViewValue(elm.val());
                });         
            });
        }
    };
});

注意:作为@wjin在下面的注释提到这个功能是通过ngModelOptions直接支持Angular 1.3(目前在测试版)。有关详细信息,请参阅the docs

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐