AngularJS執(zhí)行流程

一個Angular APP其實就是一個Angular Module,通??梢园舾蒀ontroller、Service以及Directive。

Angular App的初始化過程

1. 啟動階段
瀏覽器解析DOM樹,加載angular庫
啟動Angular應(yīng)用
2. 初始化階段
查找ng-app指令,
初始化必要組件創(chuàng)建injector
開始解析DOM樹
3. 編譯階段
遍歷DOM樹,搜集指令
執(zhí)行每個指令的Compile函數(shù),處理DOM轉(zhuǎn)換,編譯模板
調(diào)用鏈接函數(shù)生成實時視圖
4. 運行階段
等待事件觸發(fā),執(zhí)行$digest循環(huán)
檢測到變化,調(diào)用$watch函數(shù),再次執(zhí)行$digest循環(huán),直到?jīng)]有變化

流程圖:

ng-init.png

Angular APP 的啟動

  1. 自動啟動
    大部分情況下通過ng-app指令來進行自動引導(dǎo)啟動
<body ng-app="helloApp" ng-cloak>
  1. 手動啟動
    同一個頁面中可以包含多于一個的APP,但不能嵌套。同一頁面中有多于一個APP時AngularJS不會自動幫你啟動APP,你需要手動啟動這些APP
//手動啟動
angular.bootstrap(document, ['helloApp']);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容