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

React Fiber樹(shù)的構(gòu)建和替換過(guò)程講解

 更新時(shí)間:2022年12月15日 15:30:16   作者:前端小二哥  
React Fiber樹(shù)的創(chuàng)建和替換過(guò)程運(yùn)用了雙緩存技術(shù),直接將舊的 fiber 樹(shù)替換成新的 fiber 樹(shù),這樣做的好處是省去了直接在頁(yè)面上渲染時(shí)的計(jì)算時(shí)間,避免計(jì)算量大導(dǎo)致的白屏、卡頓,現(xiàn)在你一定還不太理解,下面進(jìn)行詳細(xì)講解,需要的朋友可以參考下

前言

React Fiber樹(shù)的創(chuàng)建和替換過(guò)程運(yùn)用了雙緩存技術(shù),即先在內(nèi)存中創(chuàng)建 fiber 樹(shù),待 fiber 樹(shù)創(chuàng)建完成以后,直接將舊的 fiber 樹(shù)替換成新的 fiber 樹(shù),這樣做的好處是省去了直接在頁(yè)面上渲染時(shí)的計(jì)算時(shí)間,避免計(jì)算量大導(dǎo)致的白屏、卡頓,現(xiàn)在你一定還不太理解,下面進(jìn)行詳細(xì)講解!

mount 過(guò)程

以一下demo為例進(jìn)行講解:

function App() {
  const [num, add] = useState(0);
  return (
    <p onClick={() => add(num + 1)}>{num}</p>
  )
}

ReactDOM.render(<App/>, document.getElementById('root'));
  • 首次渲染時(shí):

執(zhí)行 ReactDOM.render(<App/>, document.getElementById('root')); 創(chuàng)建一個(gè)應(yīng)用的根節(jié)點(diǎn) fiberRootNode 和 App 組件的根節(jié)點(diǎn) rootFiber,fiberRootNode節(jié)點(diǎn)會(huì)通過(guò) current 指針指向 rootFiber ;此時(shí)構(gòu)建的 fiber 樹(shù)叫 current fiber 樹(shù),沒(méi)有子節(jié)點(diǎn);

在這里插入圖片描述

  • render 階段:

此階段會(huì)在內(nèi)存中構(gòu)建一顆 workInProgress fiber 樹(shù),構(gòu)建時(shí)會(huì)與 current fiber 樹(shù)進(jìn)行 diff ,復(fù)用 current fiber 樹(shù)的 fiber 節(jié)點(diǎn),被復(fù)用的 fiber 節(jié)點(diǎn)通過(guò) alternate 指針連接;此時(shí)的 fiber 樹(shù)如下圖所示:

在這里插入圖片描述

  • commit 階段:

由于內(nèi)容在內(nèi)存中已經(jīng)構(gòu)建完成,下一步就是將內(nèi)存中的fiber樹(shù)渲染成真實(shí) DOM ,此后 React 底層將 fiberRootNode 的 current 指針指向了新構(gòu)建的 fiber 樹(shù),此時(shí) workInprogress fiber 樹(shù)變成了current fiber 樹(shù);
此時(shí)的 fiber 樹(shù)結(jié)構(gòu)如下圖:

在這里插入圖片描述

update 過(guò)程

此時(shí)點(diǎn)擊,p 元素,此時(shí)狀態(tài)改變,會(huì)觸發(fā)更新,再次進(jìn)入 render 階段,在內(nèi)存中創(chuàng)建一棵 workInProgress fiber 樹(shù),并且和 current fiber 樹(shù)進(jìn)行 diff 復(fù)用 current fiber 樹(shù)節(jié)點(diǎn),最后進(jìn)入 commit 階段 ,將構(gòu)建的fiber樹(shù)渲染到頁(yè)面上,此后 fiberRootNode 的 current 指針指向 workInProgress fiber 樹(shù),更新后的 fiber 樹(shù)如下所示:

在這里插入圖片描述

參考:React 技術(shù)揭秘

到此這篇關(guān)于React Fiber樹(shù)的構(gòu)建和替換過(guò)程的文章就介紹到這了,更多相關(guān)React Fiber樹(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解React中的不可變值

    詳解React中的不可變值

    這篇文章主要介紹了React中的不可變值的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用react.js,感興趣的朋友可以了解下
    2021-04-04
  • React-Native中禁用Navigator手勢(shì)返回的示例代碼

    React-Native中禁用Navigator手勢(shì)返回的示例代碼

    本篇文章主要介紹了React-Native中禁用Navigator手勢(shì)返回的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-09-09
  • React獲取input值并提交的2種方法實(shí)例

    React獲取input值并提交的2種方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于React獲取input值并提交的2種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • React router基礎(chǔ)使用方法詳解

    React router基礎(chǔ)使用方法詳解

    這篇文章主要介紹了React router基礎(chǔ)使用方法,React Router是React生態(tài)系統(tǒng)中最受歡迎的第三方庫(kù)之一,近一半的React項(xiàng)目中使用了React Router,下面就來(lái)看看如何在React項(xiàng)目中使用
    2023-04-04
  • React SSR樣式及SEO的實(shí)踐

    React SSR樣式及SEO的實(shí)踐

    這篇文章主要介紹了React SSR樣式及SEO的實(shí)踐,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • React實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)的方法

    React實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)的方法

    這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • React 條件渲染最佳實(shí)踐小結(jié)(7種)

    React 條件渲染最佳實(shí)踐小結(jié)(7種)

    這篇文章主要介紹了React 條件渲染最佳實(shí)踐小結(jié)(7種),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • React jsx轉(zhuǎn)換與createElement使用超詳細(xì)講解

    React jsx轉(zhuǎn)換與createElement使用超詳細(xì)講解

    這篇文章主要介紹了React jsx轉(zhuǎn)換與createElement使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-11-11
  • 詳解React中key的作用

    詳解React中key的作用

    這篇文章主要介紹了React中key的作用,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下
    2021-04-04
  • 簡(jiǎn)化Cocos和Native交互利器詳解

    簡(jiǎn)化Cocos和Native交互利器詳解

    這篇文章主要為大家介紹了簡(jiǎn)化Cocos和Native交互利器詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12

最新評(píng)論