亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

再談Angular4 臟值檢測(性能優化)

2019-11-19 13:58:08
字體:
來源:轉載
供稿:網友

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 codefunction changeDetection(component) { updateProperties(component.children); component.children.forEach(child => {  child.NgDoCheck();  child.NgOnChanges(); }; updateDom(component); component.children.forEach(child => changeDetection(child));}

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

  1. DOM更新是深度優先的
  2. NgDoCheck和NgOnChanges并不是(也不是深度優先)

OnPush - 單次檢測策略

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

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

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

Tips

數據綁定

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

直接綁定數據

<ul> <li *ngFor="let item of arr">  <span>Name {{item.name}}</span>  <span>Classes {{item.classes}}</span><!-- Binding a data directly. --> </li></ul>

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

綁定一個function調用結果

<ul> <li *ngFor="let item of arr">  <span>Name {{item.name}}</span>  <span>Classes {{classes(item)}}</span><!-- Binding an attribute to a method. The classes would be called in every change detection cycle --> </li></ul>

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

綁定數據+pipe

<ul> <li *ngFor="let item of instructorList">  <span>Name {{item.name}}</span>  <span>Classes {{item | classPipe}}</span><!-- Binding data with a pipe --> </li></ul>

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

NgFor

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

@Component({ selector: 'my-app', template: `  <ul>   <li *ngFor="let item of collection;trackBy: trackByFn">{{item.id}}</li>  </ul>  <button (click)="getItems()">Refresh items</button> `,})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; }}

Reference

  1. He who thinks change detection is depth-first and he who thinks it's breadth-first are both usually right
  2. Angular Runtime Performance Guide

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91av视频导航| 超碰精品一区二区三区乱码| 午夜精品一区二区三区在线视频| 精品亚洲国产成av人片传媒| 日韩成人中文字幕在线观看| 精品成人69xx.xyz| 国产精品欧美一区二区三区奶水| 亚洲美女动态图120秒| 神马国产精品影院av| 日韩精品欧美国产精品忘忧草| 波霸ol色综合久久| 一区二区日韩精品| 一区二区三区视频免费在线观看| 91av在线看| 97在线看福利| 日本精品免费一区二区三区| 成人久久18免费网站图片| 国产精品激情av在线播放| 国产精品久久久av久久久| 亚洲美女精品久久| 欧美一级片久久久久久久| 上原亚衣av一区二区三区| 亚洲欧美综合区自拍另类| 亚洲网站在线播放| 欧美一级电影久久| 日本国产精品视频| 亚洲成年人在线播放| 日韩中文字幕第一页| 日韩在线精品一区| 97婷婷大伊香蕉精品视频| 国产精品对白刺激| 欧美电影免费观看电视剧大全| 久久九九有精品国产23| 国产精品久久久久久久久久99| 欧美xxxx做受欧美.88| 91久久综合亚洲鲁鲁五月天| 97在线精品国自产拍中文| 日韩欧美在线国产| 久久精品影视伊人网| 欧美高清第一页| 亚洲精品一区二区三区婷婷月| 日本精品视频网站| 在线精品国产成人综合| 成人信息集中地欧美| 国产精品久久久久久一区二区| 国产精品96久久久久久又黄又硬| 91久久精品国产91久久| 欧美精品videosex牲欧美| 91精品久久久久久久久久入口| 欧美诱惑福利视频| 亚洲999一在线观看www| 国产精品一区二区久久久久| 久久精品精品电影网| 国产91精品在线播放| 国产精品专区一| 亚洲久久久久久久久久久| 国产精品一二三视频| 91豆花精品一区| 亚洲欧美在线免费观看| 久久99国产精品自在自在app| 成人免费自拍视频| 日韩欧美国产高清91| xxxxxxxxx欧美| 国产欧美日韩中文| 亚洲91精品在线| 日韩a**中文字幕| 日韩风俗一区 二区| 蜜臀久久99精品久久久久久宅男| 国产成人精品免高潮在线观看| 一本久久综合亚洲鲁鲁| 人体精品一二三区| 日韩av一区二区在线| 国产视频福利一区| 亚洲国产免费av| 91九色精品视频| 欧美日韩亚洲成人| 国产在线观看精品一区二区三区| 欧美激情xxxx性bbbb| 亚洲国产天堂久久综合网| 久久精品国产成人精品| 日本免费一区二区三区视频观看| 成人免费福利视频| 国产欧美精品一区二区三区-老狼| 精品国偷自产在线视频| 插插插亚洲综合网| 日韩在线观看免费全| 国产日韩在线精品av| 91手机视频在线观看| 岛国av午夜精品| 日韩中文字幕在线视频| 欧美综合在线观看| 亚洲天堂精品在线| 亚洲国产成人在线播放| 欧美日韩国产精品一区二区不卡中文| 亚洲午夜久久久久久久| 91国内免费在线视频| 亚洲精品自拍视频| 精品伊人久久97| 欧美激情精品久久久久久| 成人精品久久久| 欧美精品videos另类日本| 欧美一区深夜视频| 亚洲人在线观看| 日韩电影第一页| 国产丝袜精品第一页| 久久人人看视频| 2023亚洲男人天堂| 91精品国产777在线观看| 国产啪精品视频网站| 国产一区二区三区在线看| 97热在线精品视频在线观看| 7777kkkk成人观看| 亚洲欧美制服第一页| 日韩视频―中文字幕| 日韩欧美在线免费观看| 欧美亚洲另类制服自拍| 成人在线精品视频| 欧美精品第一页在线播放| 国产精品久久久久久亚洲调教| 欧美午夜精品久久久久久浪潮| 久久精品成人欧美大片| 精品国内亚洲在观看18黄| 亚洲国产另类 国产精品国产免费| 亚洲性视频网站| 一区二区国产精品视频| 亚洲一区二区三区成人在线视频精品| 高清亚洲成在人网站天堂| 日韩精品一区二区视频| 亚洲精品自在久久| 国产精品久久在线观看| 亚洲丁香婷深爱综合| 国产精品热视频| 成人做爰www免费看视频网站| 在线精品国产成人综合| 国产精品女人久久久久久| 国产自产女人91一区在线观看| 91久久精品在线| 欧美日韩色婷婷| 国产亚洲精品一区二555| 日韩乱码在线视频| 国产美女扒开尿口久久久| 亚洲伊人第一页| 日韩一区二区在线视频| 深夜福利日韩在线看| 欧美理论电影在线播放| 91精品在线国产| 欧美激情精品久久久久久变态| 欧美另类高清videos| 亚洲人成电影网站| 久久人91精品久久久久久不卡| 欧美激情久久久| 久久精品国产清自在天天线| 国产一区红桃视频| 中文字幕精品—区二区| 亚洲日本中文字幕| 欧美性xxxx在线播放| 午夜精品久久久久久久男人的天堂| 国产一区av在线| 亚洲国产高潮在线观看| 一区二区在线视频播放| 亚洲男人的天堂在线| 亚洲激情国产精品| 国产99视频精品免视看7| 日韩精品中文字幕在线观看|