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. webpack - vue-cli写的项目(本地跑没有问题),准备放到Nginx服务器上,有什么配置需要改的?还有怎么部署?2. 微信公众号发送模板消息返回错误410003. 这是什么情况???4. 关于css3兼容safari的问题5. java.lang.ClassCastException:com.sun.proxy。$Proxy0无法转换为org.andrea.myexample.myDeclarativeTransaction6. javascript - H5唤醒App7. javascript - 滚动条遮住了hover弹出层?8. Android明明可以直接分享,为什么还要用微信开放平台、微博开放平台的sdk?9. javascript - 单页面应用怎么监听ios微信返回键?10. javascript - 网易云音乐是如何实现a标签href有值不跳转的?
