激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - React - React Fiber結(jié)構(gòu)的創(chuàng)建步驟

React Fiber結(jié)構(gòu)的創(chuàng)建步驟

2022-03-02 16:36光光同學(xué)22167 React

這篇文章主要介紹了React Fiber結(jié)構(gòu)的創(chuàng)建步驟,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下

React Fiber的創(chuàng)建

當(dāng)前React版本基于V17.0.2版本,本篇主要介紹fiber結(jié)構(gòu)的創(chuàng)建。

一、開始之前

個人理解,如有不對,請指出。

首先需要配置好React的debugger開發(fā)環(huán)境,入口在這里:github

執(zhí)行npm run i,安裝依賴,npm start運行環(huán)境。

二、從React.render開始

通過在項目入口處調(diào)用React.render,打上Debug,查看React調(diào)用棧。

const root = document.getElementById("root");
ReactDOM.render(
  <React.StrictMode>
    <App />
  </React.StrictMode>,
  root
);

在React調(diào)用render之后,在傳入基礎(chǔ)的配置后,調(diào)用legacyRenderSubtreeIntoContainer。

export function render(
  element: React$Element<any>,
  container: Container,
  callback: ?Function,
) {
  // 刪除一些環(huán)境代碼
  // ...
  return legacyRenderSubtreeIntoContainer(
    null,
    element,
    container,
    false,
    callback,
  );
}

在React調(diào)用render之后,在傳入基礎(chǔ)的配置后,調(diào)用legacyRenderSubtreeIntoContainer。

export function render(
  element: React$Element<any>,
  container: Container,
  callback: ?Function,
) {
  // 刪除一些環(huán)境代碼
  // ...
  return legacyRenderSubtreeIntoContainer(
    null,
    element,
    container,
    false,
    callback,
  );
}

legacyRenderSubtreeIntoContainer一共做了兩件事情,一個是生成了fiberRoot,一個是調(diào)用updateContainer。

React Fiber結(jié)構(gòu)的創(chuàng)建步驟

進入legacyCreateRootFromDOMContainer函數(shù),查看如何生成fiberRoot。 在函數(shù)內(nèi)部,調(diào)用了createLegacyRoot,在這里區(qū)分了下,是否使用hydrate,如下:

  return createLegacyRoot(
    container,
    shouldHydrate
      ? {
        hydrate: true,
      }
      : undefined,
  );

對于createLegacyRoot來說,是用來實例化ReactDOMLegacyRoot函數(shù)的,通過后續(xù)調(diào)用,終于進入到root的生成,調(diào)用createRootImpl函數(shù),實例化root。

進入createFiberRoot函數(shù),初始化FiberRootNode。

function FiberRootNode(containerInfo, tag, hydrate) {
  this.tag = tag; // 類型
  this.containerInfo = containerInfo; // container
  this.pendingChildren = null; 
  this.current = null;
  this.pingCache = null;
  this.finishedWork = null;
  this.timeoutHandle = noTimeout;
  this.context = null;
  this.pendingContext = null;
  this.hydrate = hydrate;
  this.callbackNode = null;
  this.callbackPriority = NoLanePriority;
  this.eventTimes = createLaneMap(NoLanes);
  this.expirationTimes = createLaneMap(NoTimestamp);

  this.pendingLanes = NoLanes;
  this.suspendedLanes = NoLanes;
  this.pingedLanes = NoLanes;
  this.mutableReadLanes = NoLanes;
  this.finishedLanes = NoLanes;

  this.entangledLanes = NoLanes;
  this.entanglements = createLaneMap(NoLanes);

  // ....


}

這里的tag,有以下幾種類型。

export type RootTag = 0 | 1;

上述的結(jié)構(gòu)是fiberRootNode節(jié)點。

rootTag 等于0 時,代表legacy渲染模式,等于1時,代表Concurrent mode渲染,也就是說,傳統(tǒng)我們使用React.render進行渲染,當(dāng)調(diào)用React.createRoot時,進入Concurrent mode渲染模式,即并行渲染。

現(xiàn)在我們一起看看fiber的結(jié)構(gòu)。

  const uninitializedFiber = createHostRootFiber(tag, strictModeLevelOverride);
  root.current = uninitializedFiber;
  uninitializedFiber.stateNode = root;

uninitializedFiber為創(chuàng)建的FiberNode的創(chuàng)建的實例。

const createFiber = function(
  tag: WorkTag,
  pendingProps: mixed,
  key: null | string,
  mode: TypeOfMode,
): Fiber {
  // $FlowFixMe: the shapes are exact here but Flow doesn"t like constructors
  return new FiberNode(tag, pendingProps, key, mode);
};

通過基礎(chǔ)的創(chuàng)建,生成FiberNode結(jié)構(gòu),如下

function FiberNode(
  tag: WorkTag,
  pendingProps: mixed,
  key: null | string,
  mode: TypeOfMode,
) {
  // Instance
  this.tag = tag;//組件類型
  this.key = key;//key屬性
  this.elementType = null;//元素類型,類函數(shù),顯示類,div顯示div
  this.type = null;//func或者class
  this.stateNode = null;//dom節(jié)點

  // Fiber
  this.return = null;//指向父節(jié)點
  this.child = null;//指向子節(jié)點
  this.sibling = null;//兄弟節(jié)點
  this.index = 0;//

  this.ref = null;

  this.pendingProps = pendingProps;//等待中的屬性pendingProps
  this.memoizedProps = null; //記憶屬性,一般存放props
  this.updateQueue = null;//更新隊列
  this.memoizedState = null;// 一般存放state
  this.dependencies = null;

  this.mode = mode;

  // Effects相關(guān)
  this.flags = NoFlags;
  this.subtreeFlags = NoFlags;
  this.deletions = null;

  this.lanes = NoLanes;
  this.childLanes = NoLanes;

  this.alternate = null;//指向workInProgress
}

React Fiber結(jié)構(gòu)的創(chuàng)建步驟

 FiberNode基本顯示如上,elementType和type的基礎(chǔ)類型為function、class。

通過對比fiberRootNode結(jié)構(gòu),和下面的代碼,生成最終的FiberNode 結(jié)構(gòu)。

render() {
    const { name, count } = this.state;
    return (
      <div className="App">
          <Button name={name} />
        {
          count
        }
      </div>
    );
  }
ReactDOM.render(
  <React.StrictMode>
    <App />
  </React.StrictMode>,
  root
);

通過最后執(zhí)行,生成fiberRoot鏈表結(jié)構(gòu)。

React Fiber結(jié)構(gòu)的創(chuàng)建步驟

最后,調(diào)用unbatchedUpdates,進行渲染。

進入updateContainer函數(shù)。

unbatchedUpdates(() => {
  // 更新container
  updateContainer(children, fiberRoot, parentComponent, callback);
});

三、結(jié)束

以上就是React Fiber結(jié)構(gòu)的創(chuàng)建步驟的詳細(xì)內(nèi)容,更多關(guān)于React Fiber結(jié)構(gòu)的創(chuàng)建的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://juejin.cn/post/6950692243485229086

延伸 · 閱讀

精彩推薦
  • ReactReact.Children的用法詳解

    React.Children的用法詳解

    這篇文章主要介紹了React.Children的用法詳解,幫助大家更好的理解和學(xué)習(xí)使用React框架,感興趣的朋友可以了解下...

    uuihoo10692022-02-23
  • React必須要會的50個React面試題

    必須要會的50個React面試題

    如果你是一位有抱負(fù)的前端程序員并準(zhǔn)備面試,那么這篇文章很適合你。本文是你學(xué)習(xí)和面試 React 所需知識的完美指南。...

    瘋狂的技術(shù)宅9082022-02-23
  • ReactReact中useRef的具體使用

    React中useRef的具體使用

    這篇文章主要介紹了React中useRef的具體使用,它可以用來獲取組件實例對象或者是DOM對象,除此之外還有哪些用法,就一起來了解一下...

    Meskjei6332022-02-28
  • ReactReact html中使用react的兩種方式

    React html中使用react的兩種方式

    這篇文章主要介紹了React html中使用react的兩種方式,本文給大家提到了React pwa的配置代碼,給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒...

    愚公搬代碼6332022-02-23
  • React基于Vite 的組件文檔編寫神器,又快又省心

    基于Vite 的組件文檔編寫神器,又快又省心

    翻閱 Vite 的官方庫列表,偶然發(fā)現(xiàn)了一款 star 數(shù)量僅 100 多的文檔解決方案 vite-plugin-react-pages。開始用試試水的心態(tài)去去體驗一把,結(jié)果發(fā)現(xiàn)相當(dāng)好用。...

    前端星辰9382021-12-27
  • ReactReact利用路由實現(xiàn)登錄界面的跳轉(zhuǎn)

    React利用路由實現(xiàn)登錄界面的跳轉(zhuǎn)

    這篇文章主要介紹了React利用路由實現(xiàn)登錄界面的跳轉(zhuǎn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友...

    前端子金6422022-02-23
  • React一百多行代碼實現(xiàn)react拖拽hooks

    一百多行代碼實現(xiàn)react拖拽hooks

    這篇文章主要介紹了一百多行代碼實現(xiàn)react拖拽hooks,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下...

    孟祥_成都5952022-02-20
  • ReactWebpack3+React16代碼分割的實現(xiàn)

    Webpack3+React16代碼分割的實現(xiàn)

    這篇文章主要介紹了Webpack3+React16代碼分割的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面...

    小葉子8832022-01-25
主站蜘蛛池模板: 免费在线观看成人av | 国产男女 爽爽爽爽视频 | 欧美在线 | 亚洲 | 亚洲成人在线免费观看 | 久久久www成人免费毛片 | 青热久思思 | 国产色91 | 日本在线播放一区二区 | videos高潮 | av免费在线网 | 成人免费av在线 | 成人富二代短视频 | 国产日韩在线视频 | 黄色av片在线观看 | 天天操天天操天天操天天操天天操天天操 | 九九热在线视频观看 | 欧美精品久久久久久久久久 | 成人性生活视频在线观看 | 免费看成年人视频在线 | 亚欧在线免费观看 | 亚洲激情91 | 亚洲精品久久久久久久久久久 | 一区二区三区国产在线 | 欧美性受xxx黑人xyx性爽 | 欧美第1页 | 精品国产视频一区二区三区 | 久久综合av | 国产美女一区二区在线观看 | 欧美人的天堂一区二区三区 | 中文字幕 亚洲一区 | 青青草国产在线视频 | 91羞羞 | 久久蜜桃精品一区二区三区综合网 | 日本中文字幕久久 | 黄视频网站免费在线观看 | 9797色 | 欧美高清另类自拍视频在线看 | 亚洲电影在线观看高清免费 | 久久嗨 | 视频一区二区国产 | 国产精品久久久不卡 |