2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > angularJS 自定义指令 方法属性:controller 和属性:controllerAs

angularJS 自定义指令 方法属性:controller 和属性:controllerAs

时间:2023-03-07 09:07:48

相关推荐

angularJS 自定义指令 方法属性:controller 和属性:controllerAs

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。