自定义指令还有compile属性,这个属性是一个function, 在其中可以更改dom元素,或者进行dom元素的事件绑定等。该function中可以返还一个function,返还的这个function就是link。 自定义指令的link属性,也是一个function,通常在其中绑定dom元素的事件。
示例:
html:
一个dom上使用两个指令:custom-tags 和 custom-tags2
js:
var i=0;
angular.module('myApp',[])
//定义第一个指令:customTags
.directive('customTags',function(){
return {
restrict:'ECAM',
template:'{{ user.name }}',
replace:true,
//定义了compile就不需定义link,当compile返回一个方法这个方法就是link
//tElement 正在执行该指令的当前dom元素的jquery对象
//tAttrs 正在执行该指令的当前dom元素的属性
compile:function(tElement,tAttrs,transclude){
//第一个指令的编译阶段...
console.log('customTags compile 编译阶段...');
//若要改变dom元素,应在compile中做,此处在当前dom元素中添加一个
tElement.append(angular.element(' {{user.count}}'));
return {
//pre:编译阶段之后执行
pre:function preLink(scope,iElement,iAttrs,controller){
console.log('customTags preLink..');
},
//post:所有子元素指令的post都执行后执行,此处设置了dom元素的点击事件
post:function postLink(scope,iElement,iAttrs,controller){
iElement.on('click',function(){
scope.$apply(function(){
scope.user.name=' click after';
scope.user.count= ++i;
});
});
console.log('customTags post end.');
console.log('');
}
};
//compile也可直接返回一个方法,这就是 postLink,也就是上面的post
/*return function (){
console.log('compile return this function')
}*/
},
//进行scope绑定及事件绑定
link:function(scope,iElement,iAttrs,bookListController){
//link不会再执行了,因为这里定义的就是postLink
}
}
})
//定义第二个指令:customTags2
.directive('customTags2',function(){
return {
restrict:'ECAM',
replace:true,
compile:function(tElement,tAttrs,transclude){
console.log('customTags2 compile 编译阶段...');
return {
pre:function preLink(){
console.log('customTags2 preLink..');
},
post:function postLink(){
console.log('customTags2 post end.');
}
};
}
}
})
.controller('firstController',['$scope',function($scope){
$scope.users=[
{id:10,name:'张三',count:0}
]
}]);
执行结果:
点击“张三”一次后:
再点击一次:
改变控制器内的初始数据为:
$scope.users=[
{id:10,name:'张三',count:0},{id:20,name:'李四',count:0}
]
则执行结果为:
点击“张三”位置一次:
再点击“李四”位置一次:
再再点击“李四”位置一次:
示例中,在一个
关注一下两个指令的控制台输出,表现出的两个指令内部代码的执行顺序:
customTags compile 编译阶段...
customTags2 compile 编译阶段...
customTags preLink..
customTags2 preLink..
customTags2 post end.
customTags post end.
customTags preLink..
customTags2 preLink..
customTags2 post end.
customTags post end.
如果在customTags2后面再使用customTags3,则内部代码执行顺序:
customTags compile 编译阶段...
customTags2 compile 编译阶段...
customTags3 compile 编译阶段...
customTags preLink..
customTags2 preLink..
customTags3 preLink..
customTags3 post end.
customTags2 post end.
customTags post end.
customTags preLink..
customTags2 preLink..
customTags3 preLink..
customTags3 post end.
customTags2 post end.
customTags post end.
可以看出,针对每一个应用多个指令的dom,先依次执行指令的编译阶段,再依次执行指令的preLink代码,而post代码则是等待自己后面的指令的post都执行结束后再执行(多个指令的post执行有种栈的感觉)。