亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

對(duì)Angular中單向數(shù)據(jù)流的深入理解

 更新時(shí)間:2018年03月31日 12:03:22   作者:laoergege  
這篇文章主要給大家介紹了關(guān)于對(duì)Angular中單向數(shù)據(jù)流的深入理解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

變更檢測(cè)

Angular 中,數(shù)據(jù)是由頂部根節(jié)點(diǎn)流向最后的葉子節(jié)點(diǎn),整個(gè)數(shù)據(jù)流是單向,構(gòu)成一顆單向樹(shù)。

Angular 認(rèn)為所有的異步操作都有可能會(huì)引起模型的變化,引起數(shù)據(jù)模型發(fā)生變化的事件源有:

  • Events:click, mouseover, keyup ...
  • Timers:setInterval、setTimeout
  • XHRs:Ajax(GET、POST ...)

Angular 封裝 Zone來(lái)攔截跟蹤異步,一旦發(fā)現(xiàn)異步行為,Angular 就會(huì)進(jìn)行變更檢測(cè)。

因?yàn)閿?shù)據(jù)流是單向的,組件的數(shù)據(jù)來(lái)源只能由父組件進(jìn)行傳入,所以 Angular 會(huì)從上到下,廣度遍歷檢測(cè)組件,只要父組件檢測(cè)完畢就能繼續(xù)檢測(cè)子組件。而相比 angularjs,雙向、混亂的數(shù)據(jù)流方向,會(huì)導(dǎo)致重復(fù)變更檢測(cè)重復(fù)多次,直到數(shù)據(jù)穩(wěn)定,可能會(huì)導(dǎo)致性能問(wèn)題,或者出現(xiàn)數(shù)據(jù)和視圖處于不一致的狀態(tài),即渲染過(guò)程完成后的視圖不能反映數(shù)據(jù)的實(shí)際狀態(tài)。

渲染輸出

當(dāng)檢測(cè)到數(shù)據(jù)模型變化時(shí),組件需要重新渲染,Angular將運(yùn)行它的 DOM 生成函數(shù),該函數(shù)會(huì)生成一個(gè)新的 DOM數(shù)據(jù)結(jié)構(gòu),該結(jié)構(gòu)對(duì)應(yīng)于組件 View 的新版本。

Angular 在渲染過(guò)程中,評(píng)估模板表達(dá)式并在整個(gè)組件樹(shù)中調(diào)用生命周期鉤子。

注意:綠色標(biāo)志會(huì)多次調(diào)用

從生命調(diào)用周期來(lái)看(綠色有向線),ngAfterViewChecked 標(biāo)示該組件及子組件視圖輸出完成??匆韵乱焕樱?br />

import {Component, AfterViewChecked} from '@angular/core';
import {Course} from "./course";
@Component({
 selector: 'app-root',
 template: `
 <div class="course">
  <span class="description">{{course.description}}</span>
 </div>
`})
export class AppComponent implements AfterViewChecked {
 course: Course = {
  id: 1,
  description: "Angular For Beginners"
 };

 ngAfterViewChecked() {
  this.course.description += Math.random();
 }
}

上述代碼會(huì)在Angular變更檢測(cè)周期發(fā)生錯(cuò)誤。組件已經(jīng)完成 DOM 數(shù)據(jù)結(jié)構(gòu)輸出,我們還在該組件 ngAfterViewChecked() 方法中修改了數(shù)據(jù)狀態(tài)。這樣導(dǎo)致了視圖渲染后,數(shù)據(jù)跟視圖狀態(tài)不一致。

數(shù)據(jù)從組件類流向表示它們的DOM數(shù)據(jù)結(jié)構(gòu),生成這些DOM數(shù)據(jù)結(jié)構(gòu)的行為本身就不會(huì)導(dǎo)致數(shù)據(jù)的進(jìn)一步修改。但我們?cè)?ngAfterView 生命周期發(fā)生修改數(shù)據(jù)行為,Angular 的“單向數(shù)據(jù)流”規(guī)則禁止在一個(gè)視圖已經(jīng)被組合好之后再更新視圖。
這意味著數(shù)據(jù)模型到視圖過(guò)程是單向,不可在視圖后發(fā)生數(shù)據(jù)流發(fā)生改變。

總結(jié)

從變更檢測(cè)過(guò)程以及渲染輸出過(guò)程中,可以總結(jié)出:

單向數(shù)據(jù)流指的是從組件樹(shù)的頂部到底部渲染掃描過(guò)程中應(yīng)用程序數(shù)據(jù)流轉(zhuǎn)到由渲染過(guò)程生成的輸出DOM數(shù)據(jù)結(jié)構(gòu)的流程。

好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • AngularJS框架的ng-app指令與自動(dòng)加載實(shí)現(xiàn)方法分析

    AngularJS框架的ng-app指令與自動(dòng)加載實(shí)現(xiàn)方法分析

    這篇文章主要介紹了AngularJS框架的ng-app指令與自動(dòng)加載實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了ng-app指令的功能及自動(dòng)加載機(jī)制的實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-01-01
  • 基于AngularJS實(shí)現(xiàn)iOS8自帶的計(jì)算器

    基于AngularJS實(shí)現(xiàn)iOS8自帶的計(jì)算器

    這篇文章的主要內(nèi)容是使用angularjs實(shí)現(xiàn)一個(gè)計(jì)算器,是一個(gè)仿iOS8風(fēng)格的計(jì)算器,功能基本和iOS自帶的計(jì)算器是一致的。有需要的朋友們可以參考借鑒。
    2016-09-09
  • 詳解為Angular.js內(nèi)置$http服務(wù)添加攔截器的方法

    詳解為Angular.js內(nèi)置$http服務(wù)添加攔截器的方法

    所謂攔截器就是在目標(biāo)達(dá)到目的地之前對(duì)其進(jìn)行處理以便處理結(jié)果更加符合我們的預(yù)期。Angular的$http攔截器是通過(guò)$httpProvider.interceptors數(shù)組定義的一組攔截器,每個(gè)攔截器都是實(shí)現(xiàn)了某些特定方法的Factory。本文就介紹了為Angular.js內(nèi)置$http服務(wù)添加攔截器的方法。
    2016-12-12
  • Angularjs自定義指令Directive詳解

    Angularjs自定義指令Directive詳解

    Directive是一個(gè)非常棒的功能??梢詫?shí)現(xiàn)我們自義的的功能方法。下面通過(guò)實(shí)例代碼給大家介紹Angularjs自定義指令Directive相關(guān)知識(shí),感興趣的朋友一起學(xué)習(xí)吧
    2017-05-05
  • Angular中的NgZone.run()有什么用途

    Angular中的NgZone.run()有什么用途

    在Angular中,NgZone是一個(gè)服務(wù),用于管理異步任務(wù)的執(zhí)行,并提供一種在Angular區(qū)域內(nèi)或外部顯式運(yùn)行代碼的方式,NgZone.run方法是一種顯式在Angular區(qū)域內(nèi)運(yùn)行函數(shù)的方式,本文介紹Angular中的NgZone.run()有什么用,感興趣的朋友一起看看吧
    2024-01-01
  • AngularJS的ng-click傳參的方法

    AngularJS的ng-click傳參的方法

    本篇文章主要介紹了AngularJS的ng-click傳參的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06
  • 詳解Angular Karma測(cè)試的持續(xù)集成實(shí)踐

    詳解Angular Karma測(cè)試的持續(xù)集成實(shí)踐

    這篇文章主要介紹了詳解Angular Karma測(cè)試的持續(xù)集成實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 詳解Angular5 服務(wù)端渲染實(shí)戰(zhàn)

    詳解Angular5 服務(wù)端渲染實(shí)戰(zhàn)

    本篇文章主要介紹了詳解Angular5 服務(wù)端渲染實(shí)戰(zhàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • AngularJS使用ng-options指令實(shí)現(xiàn)下拉框

    AngularJS使用ng-options指令實(shí)現(xiàn)下拉框

    這篇文章主要介紹了AngularJS使用ng-options指令實(shí)現(xiàn)下拉框效果,ng-option指令使用也很簡(jiǎn)單,下文具體給大家說(shuō)明,對(duì)angularjs 下拉框知識(shí)感興趣的朋友一起看下吧
    2016-08-08
  • AngularJS API之copy深拷貝詳解及實(shí)例

    AngularJS API之copy深拷貝詳解及實(shí)例

    這篇文章主要介紹了AngularJS API之copy深拷貝詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2016-09-09

最新評(píng)論