React Fiber = 任务切片 + 时间切片

一句话分清

  • 任务切片 = 把一个大任务拆成很多个小任务
  • 时间切片 = 给这些小任务限定执行时间,到点就停,不卡页面

React Fiber = 任务切片 + 时间切片


1. 任务切片(Task Splitting)

是什么?

一个巨大、一口气执行不完的任务

拆成一个个可以分步执行的小单元

目的

  • 任务可以随时停下来
  • 可以随时继续
  • 可以被高优先级任务插队
  • 可以废弃旧任务

形象比喻

你要搬 1000 块砖:

  • 不切片:一次性搬完 → 累死(页面卡死)
  • 任务切片:分成 1000 次,每次搬 1 块

这就是 Fiber 做的事:

整棵虚拟 DOM 树

→ 拆成一个个 Fiber 节点

每个节点就是一个小任务单元

代码层面理解

js 复制代码
// 不切片(卡死)
for (let i=0; i<10000; i++) {
  heavyWork(i)
}

// 任务切片(拆成小任务)
let i = 0
function work() {
  heavyWork(i)
  i++
  if (i < 10000) {
    nextWork(work) // 下次再做
  }
}

任务切片 = 结构拆分


2. 时间切片(Time Slicing)

是什么?

规定:主线程每次最多只能执行 X ms(React 是 5ms)

时间一到,必须让出主线程给浏览器渲染。

目的

  • 不让 JS 长时间霸占线程
  • 保证页面流畅不卡顿
  • 保证输入、点击、动画不延迟

形象比喻

你有 1 小时搬砖时间:

  • 不切片:一直搬,不休息 → 页面卡死
  • 时间切片:每搬 5 分钟就休息一下,让页面先渲染

代码层面理解

js 复制代码
function run() {
  const start = performance.now()

  // 最多执行 5ms
  while (performance.now() - start < 5) {
    if (!hasTask()) break
    doOneTask()
  }

  // 时间到了,休息,下次继续
  schedule(run)
}

时间切片 = 时间控制


3. 两者关系(最关键)

没有任务切片 → 时间切片毫无意义

如果任务是整块不可拆分 的,

你想停也停不下来。

没有时间切片 → 任务切片白拆了

任务拆小了,但你一口气执行完

还是会卡页面。


4. 结合 React 一句话总结

Fiber 架构 =

  1. 任务切片

    把虚拟 DOM 树 → 拆成一个个 Fiber 节点

    实现:可中断、可恢复、可插队、可放弃

  2. 时间切片

    用 MessageChannel 控制每 5ms 让出主线程

    实现:不阻塞渲染、页面流畅


5. 超级精简记忆(面试必背)

  • 任务切片 = 把大任务拆小(结构层面)
  • 时间切片 = 每 5ms 强制暂停(时间层面)
  • Fiber = 任务切片 + 时间切片
  • 任务切片让它能停,时间切片让它必须停

相关推荐
ProgramHelpOa2 小时前
Amazon SDE Intern OA 2026 最新复盘|70分钟两题 Medium-Hard
java·前端·javascript
smchaopiao2 小时前
如何用CSS和JS搞定全屏图片展示
前端·javascript·css
酉鬼女又兒2 小时前
零基础快速入门前端CSS Transform 与动画核心知识点及蓝桥杯 Web 应用开发考点解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·css·职场和发展·蓝桥杯·html
山川行2 小时前
Python快速闯关8:内置函数
java·开发语言·前端·笔记·python·学习·visual studio
徐小夕3 小时前
花了一周时间,我们开源了一款PDF编辑SDK,支持在线批注+脱敏
前端·vue.js·github
前端Hardy3 小时前
Qwik 2.0 Beta 来了:不靠 AI,只靠 Resumability,首屏交互快到离谱
前端·javascript·面试
1-1=03 小时前
ExtJS 快速入门—— 面板 详细版
前端·jquery
前端攻城狮Qwen3 小时前
Service Worker在电子菜单中的实际应用
前端
前端Hardy3 小时前
NW.js v0.109.1 最新稳定版发布:被遗忘的桌面开发神器?启动快 3 倍,内存省 70%!
前端·javascript·vue.js
Kath3 小时前
[归档][2022-05-16]opensumi看码记录
前端