大佬教程收集整理的这篇文章主要介绍了angularJS 自定义指令 方法属性:controller 和属性:controllerAs,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。 示例的html:
<div ng-app="myApp"> <div ng-controller="firstController"> <div book-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><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){ }])
执行结果: - PHP - javascirp - java
点击则触发了link定义的点击事件: 并且点击会有弹窗
以上是大佬教程为你收集整理的angularJS 自定义指令 方法属性:controller 和属性:controllerAs全部内容,希望文章能够帮你解决angularJS 自定义指令 方法属性:controller 和属性:controllerAs所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。