尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

【React Fiber的重要属性】 - 教程

【React Fiber的重要属性】 - 教程
📅 发布时间:2026/6/22 15:13:45

Fiber

  • 前言
  • 核心属性
  • Fiber链表的指向关系
  • Fiber链表是如何进行遍历的

前言

可能结合我的另外两篇文章来参考
React渲染流程原理揭秘
React的Fiber及中断-重启逻辑的设计

核心属性

创建Fiber的构造函数
在这里插入图片描述

属性作用何时赋值
tagFiber类型(例子:0 函数组件 1 类组件),决定当前Fiber渲染逻辑的调用创建Fiber的时候会根据type等信息赋予对应的值
mode渲染类型, 0 同步阻塞渲染 1 中断-重启渲染继承parent Fiber的mode值,根FiberNode的mode来自于固定传入
lanes允许理解为还未处理的更新任务,只有这个值存在才会触发当前组件的重新执行,渲染新的内容调用(const [ state, setState ] = useState())setState回调函数之后会产生并凭借位运算符与加到该属性上
childchild的FiberNode(一个或者多个,多个的时候会依据sibling串成一个child链表),但注意child永远只会保存第一个child的FiberNode在父Fiber渲染之后会调用reconcileChildren生成child的FiberNode,并顺势挂载到当前child的属性上
return父FiberNode调用reconcileChildren生成child的FiberNode的时候顺势将parent的FiberNode挂载到return属性上
sibling下一个兄弟FiberNode当存在多个child的时候,在循环遍历生成child的FiberNode的时候,顺势将下一个FiberNode赋值到sibling属性上
alternate保存组件上一个态的快照,位后续渲染时比较新旧Fiber是否变化提供依据更新周期中为当前Fiber创建child Fiber的时候会为child Fiber绑定alternate属性的值
memoizedState记录当前组件的hook链(hook是React记录useState等钩子产生的对象,与Fiber一样也是链式的结构,通过next属性绑定关联关系)执行组件函数遇到useState()会产生一个hook对象,并顺势将第一个hook赋值给memoizedState属性

Fiber链表的指向关系

通过child,return,sibling这几个属性明确Fiber的指向关系就是核心
在这里插入图片描述

Fiber链表是如何进行遍历的

结合上面的图和child属性说结论,React在遍历链表Render的过程中是先深后横再回溯(child,sibling,return)。
循环的过程中,优先返回FiberNode.child作为下一次循环的值,而FiberNode.child永远只保存第一个子元素的FiberNode。因而是按照深度进行遍历,到根节点后再借助sibling遍历兄弟FiberNode,最后再借助return返回上一层节点继续遍历兄弟FiberNode。最后回到根节点然后退出循环渲染的逻辑。

相关新闻

  • 2025 年建德市摄影培训人像摄影推荐榜:路人贾摄影讲堂(建德市分公司)排名第一
  • ReactUI 渲染与交互
  • React JSX 语法详解

最新新闻

  • 嵌入式调试器环境变量配置:路径搜索原理与实战管理指南
  • Web安全实战:深入理解CSRF攻击原理与四层立体化防御体系
  • 电动车托运全攻略:跨省带电池寄运合规方法 - 快递物流资讯
  • 2026年宁波余姚装修公司推荐榜:这5家口碑排名最可靠 - 米諾
  • 从”词元出海”到”认知变现”: 我用七境体系, 把Token经济翻译成普通人能懂的知识产品
  • 2026年宁波本地装饰公司推荐与装修避坑实用指南 - 资讯快报

日新闻

  • 2026速览惠州叛逆青少年学校前十大排名名单出炉 - 武汉中职最新信息发布
  • 2026上饶白蚁消杀哪家好?15年本土2大权威白蚁防治公司推荐(金盾虫控/青蚁卫士) - 我叫一
  • 天龙八部单机版终极数据管理工具:5个技巧快速掌握游戏数据编辑

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号