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

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

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相关文章