加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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

发布时间:2020-12-17 10:31:01 所属栏目:安全 来源:网络整理
导读:自定义指令中还可以定义controller属性,是一个function,可以在其中定义数据和方法,可以提供给该指令的link内的方法使用。 示例的html: div ng-app="myApp" div ng-controller="firstController" div book-list/div /div/div js: angular.module('myApp',[

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读