在这一点上,我是AngularJS的新手。
这有效:
scope.$apply(scope.hideTooltip());
但是动态调用该函数不起作用:
scope.$apply(
scope.$eval(attrs.ngEnter, {'event': event})
);
HTML:
<input type="text" ng-model="value" ng-enter="hideToolTip()" />
enitre指令:
app.directive('ngEnter', function() {
return function(scope, element, attrs) {
console.log(scope.hideTooltip());
element.bind("keydown keypress", function(event) {
if(event.which === 13) {
console.log(attrs.ngEnter);
scope.$apply(
scope.$eval(attrs.ngEnter, {'event': event})
);
event.preventDefault();
}
});
};
});
那么,如何在AngularJS指令中动态调用函数?
最佳答案
似乎您已经错过了HTML中controller方法的参数
// you have missed the event parameter.
<input type="text" ng-model="value" ng-enter="hideToolTip(event)" />
app.directive('ngEnter', function() {
return function(scope, element, attrs) {
element.bind("keydown keypress", function(event) {
if (event.which === 13) {
console.log(attrs.ngEnter);
scope.$apply(
scope.$eval(attrs.ngEnter, {
'event': event
})
);
event.preventDefault();
}
});
};
});
在控制器中
$scope.hideToolTip = function(event) {
console.log(event);
}
这是DEMO
附言由于绑定了
keydown
和keypress
事件,因此在按ENTER键后将调用控制器函数两次。并且不要忘记删除
console.log(scope.hideTooltip());
行。