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

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

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比東阿網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式東阿網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋東阿地區(qū)。費用合理售后完善,十年實體公司更值得信賴。

一.啟動階段

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

二.初始化階段

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

三.編譯、鏈接階段

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

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

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

4.以上所有完成后,Angular啟動完成

四.運行階段

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

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

感謝你能夠認真閱讀完這篇文章,希望小編分享的“AngularJS執(zhí)行流程的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學習!

本文題目:AngularJS執(zhí)行流程的示例分析
轉(zhuǎn)載注明:http://bm7419.com/article10/iicddo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、響應(yīng)式網(wǎng)站、手機網(wǎng)站建設(shè)、企業(yè)建站、App設(shè)計關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管