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

    自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。

示例的html:

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:'
  • {{ book.name }}
', replace:true, //link中注入 bookListController ,就可以使用它的方法了 link:function(scope,iElement,iAttrs,bookListController){ iElement.on('click',bookListController.addBook); } } }) .controller('firstController',['$scope',function($scope){ }])
执行结果:



点击则触发了link定义的点击事件:

angularJS 自定义指令 方法属性:controller 和属性:controllerAs_第1张图片

你可能感兴趣的:(angular)