自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。
示例的html:
<divng-app="myApp"> <divng-controller="firstController"> <divbook-list></div> </div> </div>
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><ling-repeat="bookinbooks">{{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定义的点击事件: