自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。
示例的html:
<div ng-app="myApp">
<div ng-controller="firstController">
<div book-list></div>
</div>
</div>
js:
angular.module('myApp',[])
.directive('bookList',function(){
return {
restrict:'ECAM',
//此处定义了该指令的controller属性
controller:function($scope){
$scope.books=[
{name:'php'},
{name:'javascript'},
{name:'java'}
];
this.addBook=function(){ //或者 scope.addBook=...
alert('test');
}
},
controllerAs:'bookListController', //给当前controller起个名称
template:'<ul><li ng-repeat="book in books">{{ book.name }}</li></ul>',
replace:true,
//link中注入 bookListController ,就可以使用它的方法了
link:function(scope,iElement,iAttrs,bookListController){
iElement.on('click',bookListController.addBook);
}
}
})
.controller('firstController',['$scope',function($scope){
}])
执行结果:
点击则触发了link定义的点击事件: