标签:
需要自己编写 directives 的情况通常是当你使用了第三方的 jQuery 插件。因为插件在 AngularJS 之外对表单值进行更改,并不能即时反应到 Model 中。例如我们用得比较多的 jQueryUI datepicker 插件,当你选中一个日期后,插件会将日期字符串填到 input 输入框中。View 改变了,却并没有更新 Model,因为$(‘.datepicker‘).datepicker(); 这段代码不属于 AngularJS 的管理范围。我们需要编写一个directive 来让 DOM 的改变即时更新到 Model 里。
var directives = angular.module(‘directives‘, []);
directives.directive(‘datepicker‘, function() {
return function(scope, element, attrs) {
element.datepicker({
inline: true,
dateFormat: ‘dd.mm.yy‘,
onSelect: function(dateText) {
var modelPath = $(this).attr(‘ng-model‘);
putObject(modelPath, scope, dateText);
scope.$apply();
}
});
}
});
然后在 HTML 中引入这个 directive
<input type="text" datepicker ng-model="myObject.myDateValue" />
标签:
原文地址:http://www.cnblogs.com/toward-the-sun/p/4870378.html