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. javascript - 原生canvas中如何获取到触摸事件的canvas内坐标?2. python - Scrapy存在内存泄漏的问题。3. python - 在使用Pycharm时经常看到如下的样式,小括号里红色的部分是什么意思呢?4. CSS3 画如下图形5. javascript - Express 和 request 如何代理远程图片?6. javascript - 移动端引入js去控制根元素的font-size,但在页面初始化时会有抖动的情况,请问有别的优化方法么7. javascript - 关于<a>元素与<input>元素的JS事件运行问题8. javascript - js中向下取整9. javascript - 你们怎样实现前端分页的?10. javascript - html5的data属性怎么指定一个function函数呢?
