这看起来很简单,我在某种程度上有效,但我的解决方案存在一些问题。
场景是我想将一个函数(toggleValue()
)传递给一个指令,然后通过指令模板中的ngChange调用该函数。基本设置是:
// html
<div class="my-directive" ng-model="my_model" ng-change="toggleValue()"></div>
// angular directive
myApp.directive('myDirective', function() {
return {
scope: {
restrict: 'C',
model: '=ngModel',
action: '=ngChange'
},
template: '<input type="checkbox" ng-model="model" ng-change="action">'
}
}
这有点过于简单,因为它已经脱离了上下文,但它展示了我正在尝试做的事情。这也有效。它的问题在于它被多次调用 - 甚至在它被明确调用之前。这似乎是由于对动作的双向绑定。据我了解,&amp;应该用于隔离方法但是当我将操作更改为'&ngChange'
函数时,toggleValue()永远不会被调用。
我尝试将解决方案纳入Call a controller function from a directive without isolated scope in AngularJS,但没有取得任何成功。使用$apply()
给了我$ digest错误,使用$eval()
没有回应。
link: function (scope, element, attrs) {
scope.$eval(attrs.action);
}
答案 0 :(得分:4)
要传递函数,您需要在范围定义中使用&
而不是=
:
action: '&ngChange'
然后你需要在指令模板中调用动作:
ng-change="action()"