React组件渲染和更新的过程

一、回顾Vue组件渲染和更新的过程

二、回顾JSX本质和vdom

三、组件渲染和更新

1、组件渲染过程

  • props state (组件有了props state)
  • render()生成vnode
  • patch(elem, vnode)

2、组件更新过程

  • setState(newState) --> dirtyComponents (可能有子组件)
  • render()生成newVnode
  • patch(vnode, newVnode)

React的patch可以被拆分为2个阶段

1、reconciliation阶段-------执行diff算法, 纯JS计算

2、commit阶段--------将diff结果渲染DOM

四、fiber优化性能

可能会有性能问题

js是单线程,且和DOM渲染公用一个线程

当组件足够复杂,组件更新时计算和渲染都压力大

同时再有DOM操作需求(动画、鼠标拖拽等),将卡顿

fiber:

将reconciliation阶段进行任务拆分(commit无法拆分,dom渲染无法拆分)

DOM需要渲染时暂停,空闲时恢复
window.requestIdlecallback

(是React内部机制,开发者体会不到)

相关推荐
Moment3 分钟前
AI全栈入门指南:NestJs 中的 DTO 和数据校验
前端·后端·面试
小码哥_常13 分钟前
告别RecyclerView卡顿!8个优化技巧让列表丝滑如德芙
前端
小村儿23 分钟前
Harness Engineering:为什么你用 AI 越用越累?
前端·后端·ai编程
FrontAI25 分钟前
Next.js从入门到实战保姆级教程:环境配置与项目初始化
react.js·typescript·学习方法
enoughisenough1 小时前
浏览器判断控制台是否开启
前端
Moment1 小时前
当前端开始做 Agent 后,我才知道 LangGraph 有多重要❗❗❗
前端·后端·面试
竹林8181 小时前
RainbowKit 快速集成多链钱包连接:从“连不上”到丝滑切换的踩坑实录
前端·javascript
小蜜蜂dry1 小时前
nestjs实战-登录、鉴权(一)
前端·后端·nestjs
农夫山泉不太甜1 小时前
WebSocket与SSE技术方案选型对比分析
前端
重阳微噪2 小时前
受够了空格翻页?我写了一个 Chrome 自动滚动插件,让你真正沉浸式阅读
前端