欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React Fiber樹的構建和替換過程講解

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

前言

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

mount 過程

以一下demo為例進行講解:

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

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

執(zhí)行 ReactDOM.render(<App/>, document.getElementById('root')); 創(chuàng)建一個應用的根節(jié)點 fiberRootNode 和 App 組件的根節(jié)點 rootFiber,fiberRootNode節(jié)點會通過 current 指針指向 rootFiber ;此時構建的 fiber 樹叫 current fiber 樹,沒有子節(jié)點;

在這里插入圖片描述

  • render 階段:

此階段會在內存中構建一顆 workInProgress fiber 樹,構建時會與 current fiber 樹進行 diff ,復用 current fiber 樹的 fiber 節(jié)點,被復用的 fiber 節(jié)點通過 alternate 指針連接;此時的 fiber 樹如下圖所示:

在這里插入圖片描述

  • commit 階段:

由于內容在內存中已經構建完成,下一步就是將內存中的fiber樹渲染成真實 DOM ,此后 React 底層將 fiberRootNode 的 current 指針指向了新構建的 fiber 樹,此時 workInprogress fiber 樹變成了current fiber 樹;
此時的 fiber 樹結構如下圖:

在這里插入圖片描述

update 過程

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

在這里插入圖片描述

參考:React 技術揭秘

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

相關文章

  • 詳解React中的不可變值

    詳解React中的不可變值

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

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

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

    React獲取input值并提交的2種方法實例

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

    React router基礎使用方法詳解

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

    React SSR樣式及SEO的實踐

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

    React實現(xiàn)二級聯(lián)動的方法

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

    React 條件渲染最佳實踐小結(7種)

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

    React jsx轉換與createElement使用超詳細講解

    這篇文章主要介紹了React jsx轉換與createElement使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-11-11
  • 詳解React中key的作用

    詳解React中key的作用

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

    簡化Cocos和Native交互利器詳解

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

最新評論