angularJS 自定义指令 方法属性:controller 和属性:controller
发布时间:2020-12-17 08:45:07 所属栏目:安全 来源:网络整理
导读:angularJS 自定义指令 方法属性:controller 和属性:controllerAs 自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。 示例的html: div ng-app="myApp" div ng-controller="firstCont
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定义的点击事件: 并且点击会有弹窗 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |