angularjs雙向綁定后,發(fā)生了什么事情蜈亩?是什么可以讓view層和controller層進行綁定的懦窘?

1.背景介紹

Angular實現了雙向綁定機制

所謂的雙向綁定,無非是從界面的操作能反映到數據稚配,數據的變更能實時展現到界面畅涂。

2.知識剖析

一,如何綁定

如果我們自己實現雙向數據綁定該怎么寫?大家可以自己嘗試寫一下道川,使用原生實現雙向綁定午衰,我的demo如下立宜。

Demo1

二,MVVM

眾所周知臊岸,angular是一個MVVM(Model-View橙数,View-Model)模式的框架,可以實現數據和視圖數據綁定帅戒。MVVM把數據加工的任務從Controller中解放了出來灯帮。使得Controller只需專注于數據調配的工作。

View是angularjs編譯html后呈現出來的逻住,需要編譯的是controller中的定義的屬性和方法以及directive中定義的指令钟哥。View和controller是獨立開來的,他們之間的紐帶就是圖中間的膠水——scope瞎访。

Controller負責向scope中提供屬性和方法腻贰,便于和view層面的html進行交互。

三扒秸,如何實現

Angular雙向綁定通過$watch,$digest播演,$apply實現的。

a.watch序列

watch監(jiān)控model中是否有變化鸦采,會記錄last值宾巍,也就是改變后的值,每一個model都會增加一個watch到watch隊列中渔伯。

b.digest循環(huán)

當瀏覽器接收到可以被angular context處理的事件時顶霞,$digest循環(huán)就會觸發(fā),這個循環(huán)有兩個子循環(huán)锣吼,一個處理evalAsync隊列选浑,另一個處理watch隊列,$digest會遍歷$watch,然后詢問:

既然所有的$watch都檢查完了玄叠,那就要問了:有沒有$watch更新過古徒?如果有至少一個更新過,這個循環(huán)就會再次觸發(fā)读恃,直到所有的$watch都沒有變化隧膘。這樣就能夠保證每個model都已經不會再變化。記住如果循環(huán)超過10次的話寺惫,它將會拋出一個異常疹吃,防止無限循環(huán)。 當$digest循環(huán)結束時西雀,DOM相應地變化萨驶。

這個就是所謂的dirty-check,angular實際會引入了一個初始值為false的dirty變量作為循環(huán)條件艇肴,如果有改變過(也就是新舊值不相等)腔呜,dirty變?yōu)閠rue叁温,循環(huán)繼續(xù)。這里很重要的(也是許多人的很蛋疼的地方)是每一個進入angular context的事件都會執(zhí)行一個$digest循環(huán)核畴,也就是說每次我們輸入一個字母循環(huán)都會檢查整個頁面的所有$watch膝但。

c.$apply

那是什么決定一個事件是否進入angular context呢?

答案是$apply

我之前碰到過在angular中使用普通的事件膛檀,無法雙向綁定的事情锰镀。

app.directive('clickable', function() {

return {

restrict: "E",

scope: false,

template: '

{{foo}}

{{bar}}

',

link: function(scope, element, attrs) {

element.bind('click', function() {

scope.foo++;

});

}

}

});

app.controller('MainCtrl', function($scope) {

$scope.foo = 0;

});

demo2

這里值雖然改變了,但是沒有強制執(zhí)行$degest,監(jiān)視foo和bar的watch根本沒有執(zhí)行咖刃,執(zhí)行一次apply之后泳炉,watch就會知道這些變化,更新dom了嚎杨。這里只需要加上scope.$apply()就行了花鹅。一般帶ng的事件angular都會給你自動添加好了apply,所以你要操縱事件的時候加上aplly才能實現數據輸出到view層中枫浙。

3.常見問題

$digest和$apply有何區(qū)別刨肃?干嘛不直接使用$digest?

4.解決方案

1.$apply可以帶參數,它可以接受一個函數箩帚,然后在應用數據之后真友,調用這個函數。

2.當調用$digest的時候紧帕,只觸發(fā)當前作用域和它的子作用域上的監(jiān)控盔然,但是當調用$apply的時候,會觸發(fā)作用域樹上的所有監(jiān)控是嗜。詳情見如下demo愈案。

demo3

5.更多討論

angular context是什么?

6.參考文獻

1.view和controller的那些事兒

2.Angular沉思錄(一)數據綁定

3.理解$watch 鹅搪,$apply 和 $digest --- 理解數據綁定過程

7.鳴謝

謝謝大家觀看

BY : 劉天云 |李維文

PPT鏈接:https://ptteng.github.io/PPT/PPT/JS-08-AngularBind.html#/

視頻鏈接:


ANGULARJS雙向綁定后站绪,發(fā)生了什么事情?_騰訊視頻

技能樹.IT修真院

“我們相信人人都可以成為一個工程師丽柿,現在開始恢准,找個師兄,帶你入門甫题,掌控自己學習的節(jié)奏顷歌,學習的路上不再迷茫”幔睬。

這里是技能樹.IT修真院,成千上萬的師兄在這里找到了自己的學習路線芹扭,學習透明化麻顶,成長可見化赦抖,師兄1對1免費指導「ㄉ觯快來與我一起學習吧 队萤!

www.jnshu.com/login/1/92633351

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市矫钓,隨后出現的幾起案子要尔,更是在濱河造成了極大的恐慌,老刑警劉巖新娜,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赵辕,死亡現場離奇詭異,居然都是意外死亡概龄,警方通過查閱死者的電腦和手機还惠,發(fā)現死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來私杜,“玉大人蚕键,你說我怎么就攤上這事∷ゴ猓” “怎么了锣光?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長铝耻。 經常有香客問我誊爹,道長,這世上最難降的妖魔是什么田篇? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任替废,我火速辦了婚禮,結果婚禮上泊柬,老公的妹妹穿的比我還像新娘椎镣。我一直安慰自己,他們只是感情好兽赁,可當我...
    茶點故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布状答。 她就那樣靜靜地躺著,像睡著了一般刀崖。 火紅的嫁衣襯著肌膚如雪惊科。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天亮钦,我揣著相機與錄音馆截,去河邊找鬼。 笑死,一個胖子當著我的面吹牛蜡娶,可吹牛的內容都是我干的混卵。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼窖张,長吁一口氣:“原來是場噩夢啊……” “哼幕随!你這毒婦竟也來了?” 一聲冷哼從身側響起宿接,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤赘淮,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后睦霎,有當地人在樹林里發(fā)現了一具尸體梢卸,經...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年碎赢,在試婚紗的時候發(fā)現自己被綠了低剔。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡肮塞,死狀恐怖襟齿,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情枕赵,我是刑警寧澤猜欺,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站拷窜,受9級特大地震影響开皿,放射性物質發(fā)生泄漏。R本人自食惡果不足惜篮昧,卻給世界環(huán)境...
    茶點故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一赋荆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧懊昨,春花似錦窄潭、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至躏惋,卻和暖如春幽污,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背簿姨。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工距误, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓深寥,卻偏偏與公主長得像攘乒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子惋鹅,可洞房花燭夜當晚...
    茶點故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內容