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

来源:互联网 发布:英语学习软件开发 编辑:程序博客网 时间:2024/05/02 02:29

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


0 0
原创粉丝点击