angularJS指令中的controller和controllerAs

前端之家收集整理的这篇文章主要介绍了angularJS指令中的controller和controllerAs前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

自定义指令中还可以定义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定义的点击事件:

猜你在找的Angularjs相关文章