真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Angular4中臟值檢測(cè)的示例分析

這篇文章將為大家詳細(xì)講解有關(guān)Angular4中臟值檢測(cè)的示例分析,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián),專(zhuān)注為中小企業(yè)提供官網(wǎng)建設(shè)、營(yíng)銷(xiāo)型網(wǎng)站制作、響應(yīng)式網(wǎng)站開(kāi)發(fā)、展示型網(wǎng)站制作、成都做網(wǎng)站等服務(wù),幫助中小企業(yè)通過(guò)網(wǎng)站體現(xiàn)價(jià)值、有效益。幫助企業(yè)快速建站、解決網(wǎng)站建設(shè)與網(wǎng)站營(yíng)銷(xiāo)推廣問(wèn)題。

Summary

Angular 4的臟值檢測(cè)是個(gè)老話題了,而理解這個(gè)模型是做Angular性能優(yōu)化的基礎(chǔ)。因此,今天我們?cè)賮?lái)聊聊Angular 4臟值檢測(cè)的原理,并看看性能優(yōu)化的小提示。

進(jìn)入點(diǎn) - Zone.js

Angular 4是一個(gè)MVVM框架。數(shù)據(jù)模型(Model)轉(zhuǎn)換成視圖模型(ViewModel)后,綁定到視圖(View)上渲染成肉眼可見(jiàn)的頁(yè)面。因此,發(fā)現(xiàn)數(shù)據(jù)模型變化的時(shí)間點(diǎn)是更新頁(yè)面的關(guān)鍵,也是調(diào)用臟值檢測(cè)的關(guān)鍵。

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

臟值檢測(cè)(Change Detection)

臟值檢測(cè)的基本原理是存儲(chǔ)舊數(shù)值,并在進(jìn)行檢測(cè)時(shí),把當(dāng)前時(shí)刻的新值和舊值比對(duì)。若相等則沒(méi)有變化,反之則檢測(cè)到變化,需要更新視圖。

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

Default - 缺省策略

ChangeDetectionStrategy.Default。它還意味著一旦發(fā)生可能有數(shù)據(jù)變化的事件,就總是檢測(cè)這個(gè)組件。

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

// 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));
}

我們開(kāi)發(fā)者會(huì)非常關(guān)注DOM更新的順序,以及調(diào)用NgDoCheck和NgOnChanges的順序??梢园l(fā)現(xiàn):

  1. DOM更新是深度優(yōu)先的

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

OnPush - 單次檢測(cè)策略

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

需要注意的是,OnPush只檢測(cè)Input的引用。Input對(duì)象的屬性變化并不會(huì)觸發(fā)當(dāng)前組件的臟值檢測(cè)。

雖然OnPush策略提高了性能,但也是Bug的高發(fā)地點(diǎn)。解決方案往往是將Input轉(zhuǎn)化成Immutable的形式,強(qiáng)制Input的引用改變。

Tips

數(shù)據(jù)綁定

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

直接綁定數(shù)據(jù)

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

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

綁定一個(gè)function調(diào)用結(jié)果

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

在每個(gè)臟值檢測(cè)過(guò)程中,classes方程都要被調(diào)用一遍。設(shè)想用戶正在滾動(dòng)頁(yè)面,多個(gè)macrotask產(chǎn)生,每個(gè)macrotask都至少進(jìn)行一次臟值檢測(cè)。如果沒(méi)有特殊需求,應(yīng)盡量避免這種使用方式。

綁定數(shù)據(jù)+pipe

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

它和綁定function類(lèi)似,每次臟值檢測(cè)classPipe都會(huì)被調(diào)用。不過(guò)Angular給pipe做了優(yōu)化,加了緩存,如果item和上次相等,則直接返回結(jié)果。

NgFor

多數(shù)情況下,NgFor應(yīng)該伴隨trackBy方程使用。否則,每次臟值檢測(cè)過(guò)程中,NgFor會(huì)把列表里每一項(xiàng)都執(zhí)行更新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;  } }

關(guān)于“Angular4中臟值檢測(cè)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。


本文名稱(chēng):Angular4中臟值檢測(cè)的示例分析
當(dāng)前網(wǎng)址:http://weahome.cn/article/pehpie.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部