小更新一下

两年都为更新,冒个泡泡

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Fiber 是 React 中新的协程调度器,用于实现 React 的异步更新和并发渲染。其工作原理是通过将任务拆分成可中断的小任务单元,让浏览器有机会在任务执行期间执行其他任务,从而提高页面的响应性能和渲染速度。 下面是 Fiber 更新的大致过程: 1. 构建任务队列:将所有需要更新的组件转化成 Fiber 节点,并构建一颗 Fiber 树,形成更新任务队列。 2. 初始渲染:在首次渲染时,React 会将整个 Fiber 树都标记为需要更新,并将 Fiber 树提交到主线程进行渲染。 3. 进行工作循环:在后续的更新中,React 会将 Fiber 树中的每个节点按照一定的优先级依次加入到工作单元队列中,然后在工作单元队列中选择一个优先级最高的任务开始执行。 4. 执行任务:每个任务会执行一段代码,例如执行组件的生命周期方法、处理组件的 props 和 state 等操作,同时还会对子组件进行遍历和 diff 操作。 5. 中断任务:在任务执行过程中,如果发现当前任务已经执行了一定的时间,或者有更高优先级的任务需要执行,React 就会暂停当前任务,并将任务状态保存下来,以便恢复任务执行。 6. 任务恢复:在下次执行任务时,React 会从上次中断的位置继续执行任务,并根据需要更新组件的状态。 7. 完成任务:当一个任务执行完毕,如果该组件的状态没有变化,则该组件不需要重新渲染,否则将该组件标记为需要重新渲染,并将其子组件加入到任务队列中。 8. 提交更新:当所有任务完成后,React 会将需要更新的组件重新渲染,并将其提交到主线程进行渲染。 总之,Fiber 的更新过程是通过将任务分解为可中断的小任务单元,并根据优先级安排任务执行的顺序,从而提高 React 应用的性能和响应性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值