成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

從React渲染流程分析Diff算法

sutaking / 2737人閱讀

摘要:什么是虛擬在中,執(zhí)行的結(jié)果得到的并不是真正的節(jié)點(diǎn),結(jié)果僅僅是輕量級的對象,我們稱之為。后來產(chǎn)出的架構(gòu)模式,期望從代碼組織方式來降低維護(hù)難度。

1、什么是虛擬DOM
在React中,render執(zhí)行的結(jié)果得到的并不是真正的DOM節(jié)點(diǎn),結(jié)果僅僅是輕量級的JavaScript對象,我們稱之為virtual DOM。

簡單的說,其實(shí)所謂的virtual DOM就是JavaScript對象到Html DOM節(jié)點(diǎn)的映射;即使用JavaScript對象將Html結(jié)構(gòu)表示出來,而這個對象就是virtual DOM。

eg:

Html:

  • Item 1
  • Item 2

JavaScript對象表示(virtual DOM)

{
  tagName: "ul",
  props: {
    id: "list"
  },
  children: [
    {tagName: "li", props: {class: "item"}, children: ["Item 1"]},
    {tagName: "li", props: {class: "item"}, children: ["Item 2"]},
  ]
}
2、什么時候會生成到virtual DOM

React生命周期擁有裝載、更新、卸載的三個階段;附上一張React生命周期圖

前面提到:render執(zhí)行的結(jié)果得到的并不是真正的DOM節(jié)點(diǎn),結(jié)果僅僅是輕量級的JavaScript對象,即在render函數(shù)調(diào)用時將會創(chuàng)建出虛擬DOM;

class Tab extends React.Component {
    render() {
        React.createElement(
          "p",
          { className: "class"},
          "Hello React"
        )
    }
}

通過React.createElemen創(chuàng)建出虛擬DOM,而該函數(shù)只在Render函數(shù)中調(diào)用,所以在React裝載和更新的過程中才會有虛擬DOM的生成;至于掛載到真實(shí)DOM自然而然是ReactDom.render函數(shù)啦。

3、virtual DOM如何實(shí)現(xiàn)

實(shí)現(xiàn)其實(shí)很簡單,主要是定義一個函數(shù)并把我們傳進(jìn)去的參數(shù)組成一個React元素對象,而type就是我們傳進(jìn)去的組件類型,可以是一個類、函數(shù)或字符串(如"div")

React大致源碼:

function createElement(type, config, children) {
  let propName;

  const props = {};

  let key = null;
  let ref = null;
  let self = null;
  let source = null;

  if (config != null) {
    if (hasValidRef(config)) {
      //  如果有ref,將它取出來
      ref = config.ref;
    }
    if (hasValidKey(config)) {
      //  如果有key,將它取出來
      key = "" + config.key;
    }

    self = config.__self === undefined ? null : config.__self;
    source = config.__source === undefined ? null : config.__source;
    
    for (propName in config) {
      if (
        hasOwnProperty.call(config, propName) &&
        !RESERVED_PROPS.hasOwnProperty(propName)
      ) {
        //  將除ref,key等這些特殊的屬性放到新的props對象里
        props[propName] = config[propName];
      }
    }
  }

  //  獲取子元素
  const childrenLength = arguments.length - 2;
  if (childrenLength === 1) {
    props.children = children;
  } else if (childrenLength > 1) {
    const childArray = Array(childrenLength);
    for (let i = 0; i < childrenLength; i++) {
      childArray[i] = arguments[i + 2];
    }
    props.children = childArray;
  }

  //  添加默認(rèn)props
  if (type && type.defaultProps) {
    const defaultProps = type.defaultProps;
    for (propName in defaultProps) {
      if (props[propName] === undefined) {
        props[propName] = defaultProps[propName];
      }
    }
  }
  
  return ReactElement(
    type,
    key,
    ref,
    self,
    source,
    ReactCurrentOwner.current,
    props,
  );
}

const ReactElement = function(type, key, ref, self, source, owner, props) {
  //  最終得到的React元素
  const element = {
    // This tag allows us to uniquely identify this as a React Element
    $$typeof: REACT_ELEMENT_TYPE,

    // Built-in properties that belong on the element
    type: type,
    key: key,
    ref: ref,
    props: props,

    // Record the component responsible for creating this element.
    _owner: owner,
  };

  return element;
};

打印出組件:

4、為什么需要使用virtual DOM

DOM管理歷史階段:

JS 或者 jQuery 操作 DOM: 當(dāng)應(yīng)用程序越來越復(fù)雜,需要在JS里面維護(hù)的字段也越來越多,需要監(jiān)聽事件和在事件回調(diào)用更新頁面的DOM操作也越來越多,應(yīng)用程序會變得非常難維護(hù)。

后來產(chǎn)出 MVC、MVP 的架構(gòu)模式,期望從代碼組織方式來降低維護(hù)難度。但是 MVC 架構(gòu)并沒辦法減少維護(hù)的狀態(tài),也沒有降低狀態(tài)更新時需要對頁面的更新操作,你需要操作的DOM還是需要操作,只是換了個地方。

既然狀態(tài)改變了要操作相應(yīng)的DOM元素,為什么不做一個東西讓視圖和狀態(tài)進(jìn)行綁定,狀態(tài)變更了視圖自動變更。這就是后來人們想出了 MVVM 模式,只要在模版中聲明視圖組件是和什么狀態(tài)進(jìn)行綁定的,雙向綁定引擎就會在狀態(tài)更新的時候自動更新視圖;

但MVVM雙向數(shù)據(jù)綁定并不是唯一的辦法,還有一個非常直觀的方法:一旦狀態(tài)發(fā)生了變化,就用模版引擎重新渲染整個視圖,然后用新的視圖更換掉舊的視圖。

React采用的就是第四種模式;但是我們都知道對于操作DOM成本太高,而相對操作JavaScript就快速多了,而Html DOM可以很簡單的用JavaScript對象表示出來(Virtual DOM就這樣誕生了)

這樣的做法會導(dǎo)致很多的問題,最大的問題就是這樣做會很慢,因為即使一個小小的狀態(tài)變更都要重新構(gòu)造整棵 DOM,性價比太低;而React Virtual DOM在狀態(tài)更新過程加了一些特別的操作來避免整棵 DOM 樹變更(它就是接下來的Diff算法)。

接下來的Diff算法即將更新,敬請期待~~~

“積跬步、行千里”—— 持續(xù)更新中~,喜歡留下個贊哦!

往期經(jīng)典好文:

團(tuán)隊合作必備的Git操作

談?wù)凧s前端規(guī)范化

相關(guān)專欄推薦:

React學(xué)習(xí)之路

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/97547.html

相關(guān)文章

  • react精髓之一---diff算法

    摘要:傳統(tǒng)算法的一大特點(diǎn)就是虛擬的算法,下圖為實(shí)現(xiàn)流程圖。如果的子節(jié)點(diǎn)仍有子節(jié)點(diǎn)依舊順次執(zhí)行。我們來觀察下復(fù)雜度傳統(tǒng)算法的復(fù)雜度為,單純從看,復(fù)雜度不到,但實(shí)際上。通過制定大膽的策略,將復(fù)雜度的問題轉(zhuǎn)換成復(fù)雜度的問題。 從react渲染開始:   在說react虛擬dom之前我們先來看看react渲染過程,下面鏈接是根據(jù)源碼渲染過程寫的簡寫版。http://1.sharemandy.sina...

    Miyang 評論0 收藏0
  • React渲染流程分析Diff算法

    摘要:什么是虛擬在中,執(zhí)行的結(jié)果得到的并不是真正的節(jié)點(diǎn),結(jié)果僅僅是輕量級的對象,我們稱之為。后來產(chǎn)出的架構(gòu)模式,期望從代碼組織方式來降低維護(hù)難度。 1、什么是虛擬DOM 在React中,render執(zhí)行的結(jié)果得到的并不是真正的DOM節(jié)點(diǎn),結(jié)果僅僅是輕量級的JavaScript對象,我們稱之為virtual DOM。 簡單的說,其實(shí)所謂的virtual DOM就是JavaScript對象到H...

    lykops 評論0 收藏0
  • react基本原理及性能優(yōu)化

    摘要:對同一層級的子節(jié)點(diǎn)進(jìn)行處理時,會根據(jù)進(jìn)行簡要的復(fù)用。二性能優(yōu)化方案由于中性能主要耗費(fèi)在于階段的算法,因此性能優(yōu)化也主要針對算法。此時最常用的優(yōu)化方案即為方法。或者直接使用,原理一致。 一、從React原理談起 react是什么? showImg(https://segmentfault.com/img/bVbcYvf?w=1140&h=384); react是用于構(gòu)建用戶界面的JS框架...

    VincentFF 評論0 收藏0
  • react基本原理及性能優(yōu)化

    摘要:對同一層級的子節(jié)點(diǎn)進(jìn)行處理時,會根據(jù)進(jìn)行簡要的復(fù)用。或者直接使用,原理一致。 一、從React原理談起 react是什么? showImg(https://segmentfault.com/img/bVbcYvf?w=1140&h=384); react是用于構(gòu)建用戶界面的JS框架。因此react只負(fù)責(zé)解決view層的渲染。 react做了什么? Virtual Dom模型 生命周期...

    pinecone 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<