angularjs 事件广播(分发)与事件监听

前端之家收集整理的这篇文章主要介绍了angularjs 事件广播(分发)与事件监听前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

使用angularjs,发现controller间的值传递,比较麻烦的,以后几篇文章会陆续说几种方法

一,angularjs $broadcast $emit $on的处理思想

在一个controller里面通过事件触发一个方法,在方法里面通过$broadcast$emit来定义一个变量,在父,子controller里面通过$on获取

二,实例说明angularjs $broadcast $emit $on用法

@H_403_19@<div ng-controller="ParentCtrl"> //父级 <div ng-controller="SelfCtrl"> //自己 <a ng-click="click()">click me</a> <div ng-controller="ChildCtrl"></div> //子级 </div> <div ng-controller="BroCtrl"></div> //平级 </div>

js代码

@H_403_19@appControllers.controller('SelfCtrl',function($scope) { $scope.click = function () { $scope.$broadcast('to-child','child'); $scope.$emit('to-parent','parent'); } }); appControllers.controller('ParentCtrl',function($scope) { $scope.$on('to-parent',function(d,data) { console.log(data); //父级能得到值 }); $scope.$on('to-child',data) { console.log(data); //子级得不到值 }); }); appControllers.controller('ChildCtrl',function($scope){ $scope.$on('to-child',data) { console.log(data); //子级能得到值 }); $scope.$on('to-parent',data) { console.log(data); //父级得不到值 }); }); appControllers.controller('BroCtrl',function($scope){ $scope.$on('to-parent',data) { console.log(data); //平级得不到值 }); $scope.$on('to-child',data) { console.log(data); //平级得不到值 }); });

点击Click me的输出结果

@H_403_19@child parent

$broadcast赋的值,只能子级得到值;$emit赋的值,只能父级得到;而平级的什么都不能得到。

猜你在找的Angularjs相关文章