老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

Angular4中臟值檢測的示例分析

這篇文章將為大家詳細講解有關Angular4中臟值檢測的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創新互聯,專注為中小企業提供官網建設、營銷型網站制作、響應式網站開發、展示型網站制作、成都做網站等服務,幫助中小企業通過網站體現價值、有效益。幫助企業快速建站、解決網站建設與網站營銷推廣問題。

Summary

Angular 4的臟值檢測是個老話題了,而理解這個模型是做Angular性能優化的基礎。因此,今天我們再來聊聊Angular 4臟值檢測的原理,并看看性能優化的小提示。

進入點 - Zone.js

Angular 4是一個MVVM框架。數據模型(Model)轉換成視圖模型(ViewModel)后,綁定到視圖(View)上渲染成肉眼可見的頁面。因此,發現數據模型變化的時間點是更新頁面的關鍵,也是調用臟值檢測的關鍵。

經過分析,工程師們發現,數據的變化往往由macrotask和microtask等異步事件引起。因此,通過重寫瀏覽器所有的異步API,就能從源頭有效地監聽數據變化。Zone.js就是這樣一個猴子腳本(Monkey Patch)。Angular 4使用了一個定制化的Zone(NgZone),它會通知Angular可能有數據變化,需要更新視圖中的數據(臟值檢測)。

臟值檢測(Change Detection)

臟值檢測的基本原理是存儲舊數值,并在進行檢測時,把當前時刻的新值和舊值比對。若相等則沒有變化,反之則檢測到變化,需要更新視圖。

Angular 4把頁面切分成若干個Component(組件),組成一棵組件樹。進入臟值檢測后,從根組件自頂向下進行檢測。Angular有兩種策略:Default和OnPush。它們配置在組件上,決定臟值檢測過程中不同的行為。

Default - 缺省策略

ChangeDetectionStrategy.Default。它還意味著一旦發生可能有數據變化的事件,就總是檢測這個組件。

臟值檢測的操作基本上可以理解為以下幾步。1)更新子組件綁定的properties,2)調用子組件的NgDoCheck和NgOnChanges生命周期鉤子(Lifecycle hook),3)更新自己的DOM,4)對子組件臟值檢測。這是一個從根組件開始的遞歸方程。

// This is not Angular code
function changeDetection(component) {
 updateProperties(component.children);
 component.children.forEach(child => {
  child.NgDoCheck();
  child.NgOnChanges();
 };
 updateDom(component);
 component.children.forEach(child => changeDetection(child));
}

我們開發者會非常關注DOM更新的順序,以及調用NgDoCheck和NgOnChanges的順序。可以發現:

  1. DOM更新是深度優先的

  2. NgDoCheck和NgOnChanges并不是(也不是深度優先)

OnPush - 單次檢測策略

ChangeDetectionStrategy.OnPush。只在Input Properties變化(OnPush)時才檢測這個組件。因此當Input不變時,它只在初始化時檢測,也叫單次檢測。它的其他行為和Default保持一致。

需要注意的是,OnPush只檢測Input的引用。Input對象的屬性變化并不會觸發當前組件的臟值檢測。

雖然OnPush策略提高了性能,但也是Bug的高發地點。解決方案往往是將Input轉化成Immutable的形式,強制Input的引用改變。

Tips

數據綁定

Angular有3種合法的數據綁定方式,但它們的性能是不一樣的。

直接綁定數據

        Name {{item.name}}   Classes {{item.classes}}  

大多數情況下,這都是性能最好的方式。

綁定一個function調用結果

        Name {{item.name}}   Classes {{classes(item)}}  

在每個臟值檢測過程中,classes方程都要被調用一遍。設想用戶正在滾動頁面,多個macrotask產生,每個macrotask都至少進行一次臟值檢測。如果沒有特殊需求,應盡量避免這種使用方式。

綁定數據+pipe

        Name {{item.name}}   Classes {{item | classPipe}}  

它和綁定function類似,每次臟值檢測classPipe都會被調用。不過Angular給pipe做了優化,加了緩存,如果item和上次相等,則直接返回結果。

NgFor

多數情況下,NgFor應該伴隨trackBy方程使用。否則,每次臟值檢測過程中,NgFor會把列表里每一項都執行更新DOM操作。

@Component({
 selector: 'my-app',
 template: `
  
       {{item.id}}   
  Refresh items  `, }) export class App {  collection;  constructor() {   this.collection = [{id: 1}, {id: 2}, {id: 3}];  }     getItems() {   this.collection = this.getItemsFromServer();  }     getItemsFromServer() {   return [{id: 1}, {id: 2}, {id: 3}, {id: 4}];  }     trackByFn(index, item) {   return index;  } }

關于“Angular4中臟值檢測的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。


新聞標題:Angular4中臟值檢測的示例分析
本文URL:http://www.xueling.net.cn/article/pehpie.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 黑人女人性较视频免费视频 | a级在线视频 | 国产欧美日韩在线观看视频 | porny丨精品自拍视频 | 国产A∨天天免费观看美女 在线免费观看视频黄 | 99干b | 亚洲欧洲自拍拍偷午夜色无码 | 91爱网 | 韩国三级中文字幕HD久久精品 | 国产成人亚洲综合色影视 | 高清国产一区二区三区 | 亚洲国产成人精品一二区在线观看 | 秋霞午夜一区二区三区视频 | 蜜桃一级片 | 欧美又大又粗又硬又色A片 亚洲精品国产成人片 | 国产乱码久久久久 | 99久久国产综合精品女乱人伦 | 国产va无码高清 | 成人一级免费视频 | 樱花视频在线观看进击的巨人第三季 | 欧洲无线乱码2021 | 欧洲精品在线播放 | 亚洲欲妇 | 久久久久亚洲精品无码网址 | 久久网一区二区 | 无码AV中文出轨人妻 | 精品欧美一区二区三区久久久小说 | 欧美日韩国产一级片 | 国产精品成人片在线观看 | 免费a级网站| 国产成人久久精品二区三区牛 | 国产不卡av在线播放 | 老司机免费福利在线观看 | 色播影院性播影院私人影院 | 亚洲午夜成人精品无码软件 | 亚洲美女一级毛片 | 伊人久久大香线焦av综合影院 | 欧洲欧美人成视频在线 | 久久官网| 四虎在线视频免费观看 | 国产手机在线精品 |