Angular的工作原理

? ? 首先上一小段代碼(index.html),結合代碼我們來看看,angular一步一步都做了些什么。

復制代碼
復制代碼
<!doctype html>
<html ng-app><head><script src="angular.js"></script></head><body><png-init=" name='World' ">Hello {{name}}!</p></body> 
</html>
復制代碼
復制代碼

? ? ?當你用瀏覽器去訪問index.html的時候,瀏覽器依次做了如下一些事情:

  1. 加載html,然后解析成DOM;
  2. 加載angular.js腳本;
  3. AngularJS等待DOMContentLoaded事件的觸發;
  4. AngularJS尋找ng-app指令,根據這個指令確定應用程序的邊界;
  5. 使用ng-app中指定的模塊配置$injector;
  6. 使用$injector創建$compile服務和$rootScope;
  7. 使用$compile服務編譯DOM并把它鏈接到$rootScope上;
  8. ng-init指令對scope里面的變量name進行賦值;
  9. 對表達式{{name}}進行替換,于是乎,顯示為“Hello World!”? ? ?

  整個過程可以用這張圖來表示:



? ? ?好了,通過上面的例子我們清楚了AngularJS是怎樣一步一步渲染出一個頁面的。那么它又是如何和瀏覽器的事件回路來交互的呢?或者說是如何跟用戶來交互的呢?粗略來講,主要分為三個階段:
  1. ?瀏覽器的事件回路一直等待著事件的觸發,事件包括用戶的交互操作、定時事件或者網絡事件(如服務器的響應等);
  2. ?一旦有事件觸發,就會進入到Javascript的context中,一般通過回調函數來修改DOM;
  3. ?等到回調函數執行完畢之后,瀏覽器又根據新的DOM來渲染新的頁面。
? ? ?正如下面一張圖所示,交互過程主要由幾個循環組成:

? ? ?
? ? ?AngularJS修改了一般的Javascript工作流,并且提供了它自己的事件處理機制。這樣就把Javascript的context分隔成兩部分,一部分是原生的Javascript的context,另一部分是AngularJS的context。只有處在AngularJS的context中的操作才能享受到Angular的data-binding、exception handling、property watching等服務,但是對于外來者(如原生的Javascript操作、自定義的事件回調、第三方的庫等)Angular也不是一概不接見,可以使用AngularJS提供的$apply()函數將這些外來者包進AngularJS的context中,讓Angular感知到他們產生的變化。
? ? ?接下來,讓我們一起來看看交互過程中的這幾個循環是怎么工作的?
  1. ?首先,瀏覽器會一直處于監聽狀態,一旦有事件被觸發,就會被加到一個event queue中,event queue中的事件會一個一個的執行。
  2. ?event queue中的事件如果是被$apply()包起來的話,就會進入到AngularJS的context中,這里的fn()是我們希望在AngularJS的context中執行的函數。
  3. ?AngularJS將執行fn()函數,通常情況下,這個函數會改變應用的某些狀態。
  4. ?然后AngularJS會進入到由兩個小循環組成的$digest循環中,一個循環是用來處理$evalAsync隊列(用來schedule一些需要在渲染視圖之前處理的操作,通常通過setTimeout(0)實現,速度會比較慢,可能會出現視圖抖動的問題)的,一個循環是處理$watch列表(是一些表達式的集合,一旦有改變發生,那么$watch函數就會被調用)的。$digest循環會一直迭代知道$evalAsync隊列為空并且$watch列表也為空的時候,即model不再有任何變化。
  5. ?一旦AngularJS的$digest循環結束,整個執行就會離開AngularJS和Javascript的context,緊接著瀏覽器就會把數據改變后的視圖重新渲染出來。

? ? ?接下來,我們還是結合代碼來解析一下:

復制代碼
復制代碼
<!doctype html>
<html ng-app><head><script src="angular.js"></script></head><body><input ng-model="name"><p>Hello {{name}}!</p></body> 
</html>
復制代碼
復制代碼

? ? ?這段代碼和上一段代碼唯一的區別就是有了一個input來接收用戶的輸入。在用瀏覽器去訪問這個html文件的時候,input上的ng-model指令會給input綁上keydown事件,并且會給name變量建議一個$watch來接收變量值改變的通知。在交互階段主要會發生以下一系列事件:
  1. ?當用戶按下鍵盤上的某一個鍵的時候(比如說A),觸發input上的keydown事件;
  2. ?input上的指令察覺到input里值的變化,調用$apply(“name=‘A’”)更新處于AngularJS的context中的model;
  3. ?AngularJS將’A’賦值給name;
  4. ?$digest循環開始,$watch列表檢測到name值的變化,然后通知{{name}}表達式,更新DOM;
  5. ?退出AngularJS的context,然后退出Javascript的context中的keydown事件;
  6. ?瀏覽器重新渲染視圖。

轉載于:https://www.cnblogs.com/moriah/p/6096998.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/270438.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/270438.shtml
英文地址,請注明出處:http://en.pswp.cn/news/270438.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

php中等腰金字塔挖空,php 用for循環做,金字塔,菱形,空三角

echo "金字塔 style1";for($i1;$i<9;$i){for($k0;$kecho "*";}echo "";}echo "金字塔 style2";for($c5;$c>0;$c--){for($c10;$c1echo "*";}echo "";}echo "金字塔 style3";for($a0;$a<11;$a){…

網絡知識:四個網絡命令ping、arp、tracert、route的用法介紹

網絡相關的從業人員&#xff0c;都需要面對檢測和解決網絡故障的各種問題&#xff0c;實際案例中因為網絡導致的故障也是最多的&#xff0c;今天我們和大家一起來學習一下解決網絡故障時使用最多的四個網絡命令。希望對大家以后的實際工作中的故障排除起到作用。 1、Ping命令的…

jQuery擲骰子

網上找的jQuery擲骰子效果&#xff0c;測試兼容IE7及以上瀏覽器&#xff0c;IE6沒有測試 js代碼如下&#xff1a; 1 $(function(){2 var dice $("#dice");3 dice.click(function(){4 $(".wrap").append("<div iddice_mask><…

電腦知識:臺式電腦如何使用無線網上網

??作者主頁&#xff1a;IT技術分享社區 ??作者簡介&#xff1a;大家好,我是IT技術分享社區的博主&#xff0c;從事C#、Java開發九年&#xff0c;對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽&#xff1a; 數據庫領域優質創作者&#x1f3c6;&#x…

oracle的function的語法,Oracle function語法

2018-3-30 遇到需要使用SQL方法拼接字符串的情況&#xff0c;就研究了一下SQL簡單的方法應用--定義入參數[參數名 in 參數類型]create or replace function p_gettype(se_type in varchar2)--定義返回類型return varchar2isv_calling_type varchar2(45);v_called_type varchar2…

進程動態優先級調度

簡單的進程優先級動態調度 cup運行&#xff1a; 每執行一次&#xff0c;優先級減一&#xff0c;運行時間減一。 就緒隊列中的進程&#xff1a;每次按優先級降序排序&#xff08;優先級越大越優先執行&#xff09;&#xff0c;若優先級相等再按時間升序排序&#xff08;時間越小…

電腦維修:如何給筆記本電腦升級內存條

??作者主頁&#xff1a;IT技術分享社區 ??作者簡介&#xff1a;大家好,我是IT技術分享社區的博主&#xff0c;從事C#、Java開發九年&#xff0c;對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽&#xff1a; 數據庫領域優質創作者&#x1f3c6;&#x…

php動態添加查詢,php動態添加url查詢參數的方法,php動態url參數_PHP教程

php動態添加url查詢參數的方法&#xff0c;php動態url參數本文實例講述了php動態添加url查詢參數的方法。分享給大家供大家參考。具體分析如下&#xff1a;這段代碼可以動態為url添加key-value查詢參數&#xff0c;如果參數已經存在則會用新的進行覆蓋function add_querystring…

Object o = new Object()在內存中占幾個字節

CAS&#xff1a; Compare and Swap&#xff0c;即比較再交換。 jdk5增加了并發包java.util.concurrent.*,其下面的類使用CAS算法實現了區別于synchronouse同步鎖的一種樂觀鎖。JDK 5之前Java語言是靠synchronized關鍵字保證同步的&#xff0c;這是一種獨占鎖&#xff0c;也是…

MYSQL筆記:刪除操作Delete、Truncate、Drop用法比較

今天小編給大家梳理一下MYSQL刪除操作Delete、Truncate、Drop用法有什么區別&#xff0c;到底該如何合理使用&#xff0c;希望對大家能有幫助&#xff01;1、執行速度比較Delete、Truncate、Drop關鍵字都可以刪除數據drop>truncate>delete2、原理方面2.1 deletedelete屬于…

php常用函數

//php curl get獲取head頭部跳轉參數function get_head($sUrl){$oCurl curl_init(); // 設置請求頭, 有時候需要,有時候不用,看請求網址是否有對應的要求$header[] "Content-type: application/x-www-form-urlencoded";$user_agent "Mozilla/5.0 (Windows NT…

partition oracle用法,Oracle partition by 使用說明

--用法詳解0、select * from wmg_test; ---測試數據1、select v1,v2,sum(v2) over(order by v2) as sum --按照 v2排序&#xff0c;累計nn-1....1from wmg_test;2、select v1,v2,sum(v2) over(partition by v1 order by v2) as sum --先分組&#xff0c;組內在進行…

SQLServer優化:SQLServer中NOLOCK關鍵字的用法介紹

目錄 1、為什么SQLServer有NOLOCK關鍵字&#xff1f; 2、SQLServer有NOLOCK有什么問題 3、NOLOCK使用場景 4、nolock和with(nolock)的區別 5、表解鎖腳本 1、為什么SQLServer有NOLOCK關鍵字&#xff1f; SQLServer沒創建一個查詢&#xff0c;都相當于創建一個查詢會話&#xff…

20144303 20145239 實驗三

20144303 20145239 實驗三 實驗內容 1、首先連接好實驗箱電源&#xff0c;用串口線、并口線、網線、連接實驗箱和主機 2、安裝ADS并破解 安裝文件在00-ads1.2目錄下&#xff0c;破解方法在00-ads1.2\Crack目錄下 3、安裝GIVEIO驅動(安裝文件在01-GIVEIO目錄下) 把整個GIVEIO目錄…

oracle無法創建監聽器,關于Oracle net Manager中點擊無法創建監聽程序的解決方案

首先查看你的環境變量中是否有如果沒有請添加該環境變量。變量名為&#xff1a;TNS_ADMIN 變量值為&#xff1a;E:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN;(如果你更改了默認目錄&#xff0c;請找到相應的目錄加進去)&#xff0c;添加完成之后&#xff0c;…

辦公技巧:分享5個非常好用的Excel插件

??作者主頁&#xff1a;IT技術分享社區 ??作者簡介&#xff1a;大家好,我是IT技術分享社區的博主&#xff0c;從事C#、Java開發九年&#xff0c;對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽&#xff1a; 數據庫領域優質創作者&#x1f3c6;&#x…

weblogic安全漫談

今天&#xff0c;我來與大家探討一下關于weblogic的話題 在進入內網后&#xff0c;如圖&#xff1a; 當我們看到7001時&#xff0c;我們就可以測試weblogic反序列化漏洞&#xff0c;如圖&#xff1a; 證明&#xff0c;漏洞存在&#xff0c;查看一下權限&#xff0c;如圖&#x…

linux使進程不依賴終端,Linux?nohup命令應用簡介--讓Linux的進程不受終端影響

nohup命令應用簡介--讓Linux的進程不受終端影響by:授客QQ&#xff1a;1033553122#開啟ping進程[rootlocalhost ~]# pinglocalhost &[2] 4169[1]Terminatednohup ping localhost[rootlocalhost ~]# PINGlocalhost (127.0.0.1) 56(84) bytes of data.64 bytes from localhost…