AngularJS中的事件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AngularJS中的事件相关的知识,希望对你有一定的参考价值。

欢迎大家指导与讨论 : )

  前言

   Angular的作用域在本质上是分层次的(有的住户在低层, 有的住户在高层), 它们可以通过父子关系很自然地进行沟通。但通常, 这种沟通是单向的(父->子的单向沟通), 并且它们的作用域不共享变量, 它们的执行功能往往也各不相同, 也与它们父树上的位置无关。因此,在这种情况下,我们可以通过在这个链上传递事件的方式在作用域之间通讯(住在第n层的居委会主席对他的手下说: ‘嘿! 哥们! 麻烦帮我逐层告诉这栋楼的楼上/楼下的住户, 他们该交电费啦!‘)。注意, 受作用的只有某条链(隔壁楼的住户可不会听你的话哦)

  彩蛋——父子作用域间共享变量

  如果才能令父子作用域间可共享变量呢?(不单是父->子的方向, 还有子->父的方向)。答案是, 让子作用域"继承"父作用域$scope对象上的某一对象。

    <div ng-controller="parent">
        父:{{ model.test }}
        <button ng-click="change1();">点我by父亲</button>
        <div ng-controller="child">
            子:{{ model.test }}
            <button ng-click="change2();">点我by儿子</button>
        </div>
    </div> 

 

    app.controller(‘parent‘, [‘$scope‘, function($scope){
        $scope.model = {};
        $scope.model.test = ‘父亲‘;
        $scope.change1 = function(){
            $scope.model.test = ‘父亲导致的改变‘;
        }
    }]);
    app.controller(‘child‘, [‘$scope‘, function($scope){
        $scope.change2 = function(){
            $scope.model.test = ‘儿子导致的改变‘;
        }
    }])

  通讯——在链上传递事件

  下面的这个例子可以说明, 在一个"根"作用域下, 设置了两条"链"(两栋楼)。 实验可见: 楼A的事件传递, 不会被楼B的住户所接受:事件传递是在单链上的。但每条链的链头必定是$rootScope作用域

<body ng-controller="rootController">
    <div ng-controller="leftParent">
        <div ng-controller="SelfCtrl">
            <a ng-click="click();">点我</a>
            <div ng-controller="ChildCtrl"></div>
        </div>
        <div ng-controller="BroCtrl"></div>
    </div>
    <div ng-controller="rightParent">
        
    </div>
</body>

 

    app.controller(‘rootController‘, [‘$scope‘, function($scope){
        
    }]);
    app.controller(‘leftParent‘, [‘$scope‘, function($scope){
        $scope.$on(‘to-parent‘, function(d,data) {  
            console.log(data);         //父级能得到值  
        });  
        $scope.$on(‘to-child‘, function(d,data) {  
            console.log(data);         //子级得不到值  
        });        
    }]);
    app.controller(‘SelfCtrl‘, [‘$scope‘, function($scope){
        $scope.click = function(){
            $scope.$broadcast(‘to-child‘, ‘child‘);
            $scope.$emit(‘to-parent‘, ‘parent‘);
        }
    }]);
    app.controller(‘ChildCtrl‘, [‘$scope‘, function($scope){
        $scope.$on(‘to-child‘, function(d,data) {  
            console.log(data);         //子级能得到值  
        });  
        $scope.$on(‘to-parent‘, function(d,data) {  
            console.log(data);         //父级得不到值  
        });        
    }]);
    app.controller(‘BroCtrl‘, [‘$scope‘, function($scope){
        $scope.$on(‘to-parent‘, function(d,data) {  
            console.log(data);        //平级得不到值  
        });  
        $scope.$on(‘to-child‘, function(d,data) {  
            console.log(data);        //平级得不到值  
        });          
    }]);

    app.controller(‘rightParent‘, [‘$scope‘, function($scope){
        $scope.$on(‘to-parent‘, function(d,data) {  
            console.log(data);         //其它链上不能获取事件  
        });  
        $scope.$on(‘to-child‘, function(d,data) {  
            console.log(data);         //其它链上不能获取事件
        });        
    }]);

  传递的方向——$broadcast和$emit

  一方面, 如果要提醒一个全局模块, 我们最终需要通知高层次的作用域(如$rootScope), 则需要把事件向上传递($emit)。另一方面, 如果是一个选项卡指令和它的子面板指令之间的通讯, 则把事件向下传递($broadcast)

    $broadcast(name, args){//...}  $emit(name, args)(//...) 其中, name是事件的名称, 而args是参数集合(可以把参数集合到某一$scope对象里, 再把该对象传出)

  

  资料参考

   《AngularJS权威指南》P287

以上是关于AngularJS中的事件的主要内容,如果未能解决你的问题,请参考以下文章

AngularJS中的DOM与事件

浅谈AngularJS中的$parse和$eval

在AngularJS中的滚动事件上获取鼠标位置

在AngularJS中的滚动事件上获取鼠标位置

如何在AngularJS中的两个控制器之间广播事件

从 AngularJS url 中删除片段标识符(# 符号)