你几乎是对的。
第一个错误是当你定义dynamicMethods
你正在引用的对象时$scope.blabla
,它还不存在。
第二个错误是当您将值传递给accept
绑定到父范围的函数调用时,您需要将其传递为:
$scope.accept({msg: "from dir"})
wheremsg
是一个名为的局部变量,可以在accept
自定义指令调用的属性表达式值中使用<editkeyvalue accept="dynamicMethods.myMethod(msg)" ...
我已经相应地更新了你的小提琴。
当您写作时,accept: "&"
您是在告诉 Angular 到
- 使用
$parse
服务解析表达式 ( dynamicMethods.myMethod(msg)
)
- 从步骤 1 返回的函数的“绑定”(通过javascript 闭包)到原始范围(在您的情况下为控制器的范围)
$scope
- 将函数存储在
accept
指令本地范围的属性内。
现在,如果您$scope.accept
在指令中调用它之前检查内容,您将类似于:
function (locals) {
return parentGet(parentScope, locals);
}
wherelocals
是一个具有局部变量的对象,当我们对从 . 返回的函数进行评估时使用$parse
。由于 javascript 中没有命名参数,我们不想以某种方式指出 value 局部变量msg
是“来自 dir”,我们将它作为一个简单的对象传递,其中 key 表示变量 name {msg: "from dir"}
。
Angular 会查看表达式(一个字符串)来评估并msg
在括号内找到它,因此它看起来像一个参数,可以在locals
对象中找到该值。
当需要调用实际函数时,angular 会将locals
对象转换为常规数组 - 保留它从表达式中读取的参数顺序并以类似于以下方式调用函数:
var locals = {msg: "from dir"};
var targetFn = dynamicMethods.myMethod;
var context = dynamicMethods;
targetFn.apply(context, ["from dir"]);
希望这有助于了解正在发生的事情。