JavaScript使用$ scope。$ emit和$ scope。$ on
首先,父子范圍關(guān)系確實(shí)很重要。你有兩種可能性發(fā)出某些事件:
$broadcast -將事件向下分發(fā)到所有子范圍,$emit-通過范圍層次結(jié)構(gòu)向上調(diào)度事件。我對(duì)你的控制器(作用域)關(guān)系一無所知,但是有幾種選擇:
如果scope of firstCtrl是作用域的父級(jí),則secondCtrl你的代碼應(yīng)通過替換$emit為$broadcastin來工作firstCtrl:
function firstCtrl($scope){ $scope.$broadcast(’someEvent’, [1,2,3]);}function secondCtrl($scope){ $scope.$on(’someEvent’, function(event, mass) { console.log(mass); });}
如果你的范圍之間沒有父子關(guān)系,則可以注入$rootScope控制器并將事件廣播到所有子范圍(即secondCtrl)。
function firstCtrl($rootScope){ $rootScope.$broadcast(’someEvent’, [1,2,3]);}最后,當(dāng)你需要將事件從子控制器分派到向上作用域時(shí),可以使用$scope.$emit。如果的范圍firstCtrl是范圍的父級(jí)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方法將對(duì)象從一個(gè)控制器發(fā)送到另一個(gè)控制器?
function firstCtrl($scope) { $scope.$emit(’someEvent’,[1,2,3]);}function secondCtrl($scope) { $scope.$on(’someEvent’,function(mass) { console.log(mass); });}
它不按我認(rèn)為的方式工作。如何做$emit和$on工作?
相關(guān)文章:
1. docker網(wǎng)絡(luò)端口映射,沒有方便點(diǎn)的操作方法么?2. docker start -a dockername 老是卡住,什么情況?3. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?4. docker gitlab 如何git clone?5. dockerfile - [docker build image失敗- npm install]6. docker不顯示端口映射呢?7. docker-compose 為何找不到配置文件?8. 對(duì)html實(shí)現(xiàn)監(jiān)測 發(fā)現(xiàn)不對(duì)9. 前端 - 使用css畫一個(gè)矩形?10. html - 誰能解釋這個(gè)現(xiàn)象??
