html
<input my-datepicker name="test" callback="vm.callback()"/>
javascript
module.directive('myDatepicker', function(){ return { scope : { callback : '&' }, link : function( scope, el ){ el.datepicker({ change : function(){ scope.callback(); } }); }, }; }); module.controller('myCtrl', function(){ vm.callback = function(){ //一些代码 } });
我知道通过指定scope
中的绑定策略为&
,可以实现调用controller
中的定义的回调函数。
我的问题是,何时该使用=
编写指令?有何效果?啊,跪求大神解答~~
=
是表达式关联,我们还是从一个简单的例子来看问题:这涉及到自定义指令的时候,如果你创建了单独的scope,如何“继承”来自父scope的数据问题。
符号定义有三种,
@
,=
, 和&
,分别代表的意思是:把当前属性作为字符串传递
,绑定当前属性,它带有一个来自指令父scope的属性,如同楼上说的那样
,传递一个来自父scope的函数,可以稍后调用,调用的时候可以传递数据,例如scope.callback({a:'xxx',b:'yyy'})