如何在console 里 打印 React Fiber 树?

众所周知React的性能好得益于 他杰出特性 Fiber架构设计, React Fiber 是 React 16 中引入的新的协调引擎或重写的核心算法, 真针Fiber的一个重要的核心概念Fiber Node。 Fiber Node 是对组件的实力在js代码层面的结构数据表现。 每个 Fiber Node 对应一个 React Element,并包含了关于组件的信息,比如其类型、属性等。Fiber Node 节点的关联组织 构成了Fiber Tree。 至于如何构建, 怎么diff 调和等 这里就不过多赘述。

这次主要的研究对象是: 如何从使用者/学习 者角度 在js 代码上 拿到fiber 树结构的信息。 比如页面构建完成后, console 对应的fiber tree 的json。

  1. 第一步:

    react 切入项目入口是在 ReactDom.render() 。如下图:

    又或者是通过createRoot 进而render 。 如下图:

  2. 第二步:

    查看react render 的源码 一探究竟。

    走到这里 大致就比较清晰了, 在root 节点上增加以字符串"__reactContainer" + 随机数 的属性, 属性值就是fiberRoot 节点。

    那是不是我们只要通过dom 节点 获取root 节点的"__reactContainer" + 随机数 的属性 就找到了react 的树节点, 夜就拿到了整棵树。

    流程图如下:

    3. 开始实施。

    js 复制代码
    const container = document.getElementById("app");
    Object.getOwnPropertyNames(container).forEach(key =>{
        if(key.startsWith("__reactContainer")){
            console.log(key, container[key])
        }
    } )

    控制台输出如下图

总结:

react 的fiber 是挂在了dom root 节点上 ["__reactContainer" + 随机值] 的, 但是不建议依赖__reactContainer$和随机键来获取Fiber节点,而是应该使用React提供的官方API和工具来管理组件和调试应用程序。

相关推荐
马可菠萝几秒前
从零开始,用 Tauri + Vue 3 打造轻量级桌面应用
前端
陆枫Larry1 分钟前
JavaScript 字符串处理实战:从 `startsWith` 到链式 `replace` 的避坑指南
前端
天蓝色的鱼鱼18 分钟前
你的项目真的需要SSR吗?还是只是你的简历需要?
前端·架构
恋猫de小郭1 小时前
移动端开发稳了?AI 目前还无法取代客户端开发,小红书的论文告诉你数据
前端·flutter·ai编程
文心快码BaiduComate1 小时前
百度云与光本位签署战略合作:用AI Agent 重构芯片研发流程
前端·人工智能·架构
闲云一鹤2 小时前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
QCY2 小时前
「完全理解」1 分钟实现自己的 Coding Agent
前端·agent·claude
一拳不是超人2 小时前
Electron主窗口弹框被WebContentView遮挡?独立WebContentView弹框方案详解!
前端·javascript·electron
anyup3 小时前
🔥2026最推荐的跨平台方案:H5/小程序/App/鸿蒙,一套代码搞定
前端·uni-app·harmonyos
雮尘3 小时前
如何在非 Claude IDE (TARE、 Cursor、Antigravity 等)下使用 Agent Skills
前端·agent·ai编程