【发布时间】:2014-03-03 20:18:53
【问题描述】:
我有一个指令 barFoo,它具有以下模板:
<div>
....
<input ng-model="data">
</div>
该指令在表单中使用!现在,在这个指令中,我想做一些事情,比如
element.find('input').$setValidity('bar-valid', false);
但是,这不起作用。此外,输入字段没有 name 属性。 没有'name'属性有没有办法做到这一点?
更新:另一种解决方案是在指令元素上定义 ngModel
<bar-foo ng-model="data.value"></bar-foo>
并将指令改写如下
....
.directive('barFoo', function () {
return {
require: 'ngModel',
...
link: function (scope, element, attrs, ctrl) {
ctrl.$setValidity('bar-valid', false);
}
});
【问题讨论】:
标签: javascript angularjs angularjs-directive angularjs-ng-form