调用function passed into Angular指令返回该函数,而不是调用它
Calling function passed into Angular directive returns the function rather than calling it
我想在指令的作用域参数中使用&
将一个函数传递给指令:
.directive('myDirective', function(){
return {
scope: {
'fn': '&',
},
link: function(scope,el, attrs){
console.log(scope.fn());
}
}
});
然后调用link
中的函数并记录返回值。
在模板中,我传递了一个函数,它应该只是警告"ok"到指令:
<div ng-controller="MyController">
<div my-directive fn="myFn"></div>
</div>
代码在这个Plunkr中,但是它记录函数而不是调用它:
function (){
alert('ok')
}
为什么不调用函数?
&
不传递一个函数到指令,它传递一个表达式。在该表达式中,您需要调用以下函数:
<div my-directive fn="myFn()"></div>
当只做myFn
时,Angular将计算表达式并只返回函数的值。
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量