溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

AngularJS執(zhí)行流程的示例分析

發(fā)布時(shí)間:2021-07-27 14:44:30 來源:億速云 閱讀:184 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了AngularJS執(zhí)行流程的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一.啟動(dòng)階段

瀏覽器解析HTML頁面,讀取到angular.js的<script>標(biāo)簽后會(huì)停止解析后面的DOM節(jié)點(diǎn),開始執(zhí)行angular.js,與此同時(shí),Angular會(huì)設(shè)置一個(gè)事件監(jiān)聽器來監(jiān)聽DOMContentLoaded事件,當(dāng)Angular監(jiān)聽到這個(gè)事件后,Angular就啟動(dòng)了。

二.初始化階段

Angular啟動(dòng)后,它會(huì)查找ng-app指令,然后初始化一系列必要的組件(即$injector、$compile服務(wù)以及$rootScope),接著繼續(xù)解析DOM。

三.編譯、鏈接階段

1.Angular使用$compile服務(wù)通過遍歷DOM樹的方式查找?guī)в兄噶畹腄OM元素,然后根據(jù)指令的priority優(yōu)先級(jí)對(duì)這些查找到的指令進(jìn)行排序。

2.之后使用$injector服務(wù)查找和收集每個(gè)指令下面的compile函數(shù),并執(zhí)行它。

3.每個(gè)節(jié)點(diǎn)的compile方法運(yùn)行之后,$compile服務(wù)就會(huì)調(diào)用鏈接函數(shù)。這個(gè)鏈接函數(shù)為綁定了封閉作用域的指令設(shè)置監(jiān)控。這一行為會(huì)創(chuàng)建實(shí)時(shí)視圖。

4.以上所有完成后,Angular啟動(dòng)完成

四.運(yùn)行階段

Angular提供了自己的事件循環(huán)。指令自身會(huì)注冊(cè)事件監(jiān)聽器,因此當(dāng)事件被觸發(fā)時(shí),指令函數(shù)就會(huì)運(yùn)行在AngularJS的$digest循環(huán)中。$digest循環(huán)會(huì)等待$watch表達(dá)式列表,當(dāng)檢測到模型變化后,就會(huì)調(diào)用$watch函數(shù),然后再次查看$watch列表以確保沒有模型被改變。一旦$digest循環(huán)穩(wěn)定下來,并且檢測到?jīng)]有潛在的變化了,執(zhí)行過程就會(huì)離開Angular上下文并且通常會(huì)回到瀏覽器中。

AngularJS執(zhí)行流程的示例分析

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“AngularJS執(zhí)行流程的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI