国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

Angularjs全局變量被作用域監聽的正確姿勢

2024-05-06 16:28:04
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Angularjs全局變量被作用域監聽的正確姿勢的相關資料,需要的朋友可以參考下
 

如果你只想知道結論:

$scope.$watch($rootScope.xxx,function(newVal,oldVal){//do something})

馬上就有人問為什么不是:

$rootScope.$watch("xxx",function(newVal,oldVal){//do something})

從我最近的一個bug來說說為什么要用第一種方式。

邏輯如圖,一開始我使用了 $rootScope.$watch 的寫法。因為 angularjs 在 $rootScope 上的 watch 一旦注冊全局有效。而我的這個全局變量恰好是訂單信息,也就是說不同的 controller 對他都是有改動的,每一次改動就會觸發 $rootScope.$watch 進入別的 controller。可以類比看一下 $rootScope 上的 $broadcast 會全局出發的。

其實這并不是唯一的方式,查一下angular 源碼不難找到 watch 方法源碼不分有如下代碼:

return function deregisterWatch() {if (arrayRemove(array, watcher) >= 0) {incrementWatchersCount(scope, -1);}lastDirtyWatch = null;};

這段代碼告訴我們,手動清理 watch 是可行的。例如:

var watcher = $rootScope.$watch("xxx",function(){});//手動清除 watcher watcher();

還是很簡單對吧,以上方法同樣可以用于 scope 上的 watch。

研究到這里的時候,覺得有點問題,那我在 $scope 會被清理么?于是呼,繼續翻源碼,我在 $destroy 方法里面找到如下代碼:

// Disable listeners, watchers and apply/digest methodsthis.$destroy = this.$digest = this.$apply = this.$evalAsync = this.$applyAsync = noop;this.$on = this.$watch = this.$watchGroup = function() { return noop; };this.$$listeners = {};

以上代碼是本文給大家介紹的Angularjs全局變量被作用域監聽的正確姿勢,希望大家有所幫助,本文寫的不好還請各位大俠多多指教。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 建湖县| 涟水县| 乐平市| 罗定市| 双流县| 永川市| 祥云县| 滨州市| 三都| 金乡县| 涿州市| 万宁市| 榆林市| 肃南| 浑源县| 龙口市| 耒阳市| 什邡市| 大宁县| 青冈县| 阿瓦提县| 顺昌县| 榆社县| 保山市| 闽侯县| 道孚县| 汾西县| 平潭县| 沁阳市| 渭源县| 昌宁县| 黔西县| 垣曲县| 乐东| 谷城县| 金山区| 南召县| 定边县| 林口县| 施甸县| 岑巩县|