自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。
示例的html:
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:'
- { { book.name }}
执行结果:
点击则触发了link定义的点击事件: