JavaScript使用$ scope。$ emit和$ scope。$ on
首先,父子范围关系确实很重要。你有两种可能性发出某些事件:
$broadcast -将事件向下分发到所有子范围,$emit-通过范围层次结构向上调度事件。我对你的控制器(作用域)关系一无所知,但是有几种选择:
如果scope of firstCtrl是作用域的父级,则secondCtrl你的代码应通过替换$emit为$broadcastin来工作firstCtrl:
function firstCtrl($scope){ $scope.$broadcast(’someEvent’, [1,2,3]);}function secondCtrl($scope){ $scope.$on(’someEvent’, function(event, mass) { console.log(mass); });}
如果你的范围之间没有父子关系,则可以注入$rootScope控制器并将事件广播到所有子范围(即secondCtrl)。
function firstCtrl($rootScope){ $rootScope.$broadcast(’someEvent’, [1,2,3]);}最后,当你需要将事件从子控制器分派到向上作用域时,可以使用$scope.$emit。如果的范围firstCtrl是范围的父级secondCtrl:
function firstCtrl($scope){ $scope.$on(’someEvent’, function(event, data) { console.log(data); });}function secondCtrl($scope){ $scope.$emit(’someEvent’, [1,2,3]);}解决方法
如何$scope使用.$emit和.$on方法将对象从一个控制器发送到另一个控制器?
function firstCtrl($scope) { $scope.$emit(’someEvent’,[1,2,3]);}function secondCtrl($scope) { $scope.$on(’someEvent’,function(mass) { console.log(mass); });}
它不按我认为的方式工作。如何做$emit和$on工作?
相关文章:
1. node.js - 关于你不知道的JavaScript上一书介绍的行为委托2. android clickablespan获取选中内容3. javascript - 最终生成的jsBundle文件压缩问题4. docker安装后出现Cannot connect to the Docker daemon.5. 关于docker下的nginx压力测试6. python - TypeError: tryMsgcode() takes exactly 2 arguments (0 given)7. 关于Java引用传递的一个困惑?8. angular.js - angularjs的自定义过滤器如何给文字加颜色?9. javascript - canvas 裁剪空白区域10. nignx - docker内nginx 80端口被占用
