react useDeferredvalue和useTransition的讲解

我给你用最简单、最直白、面试必过、一看就懂 的方式,彻底讲透 React 的 useDeferredValue + useTransition

一句话核心结论

这两个 React 18 新 Hook ,专门解决:
大量数据渲染、复杂计算 → 导致页面卡顿、输入框延迟 的问题!

它们的作用:
让高优先级操作(输入、点击)不卡顿,低优先级操作(大数据渲染、复杂计算)延后执行。


先看场景(你一定遇到过)

js 复制代码
const [text, setText] = useState('')
const list = filterBigList(text) // 超级耗性能,2万条数据

return (
  <>
    <input value={text} onChange={(e) => setText(e.target.value)} />
    <div>{list.map(item => <div>{item}</div>)}</div>
  </>
)

问题:

输入框打字 → 触发大数据过滤 → 页面卡死、延迟、掉帧

原因:

输入和渲染是同步高优先级,一起执行,UI 被阻塞。


一、useTransition(最常用)

作用

非紧急、耗性能的更新 标记为 低优先级更新

高优先级(输入)可以插队,页面永远不卡!

核心 API

js 复制代码
const [isPending, startTransition] = useTransition()
  • isPending:低优先级任务是否在等待(可展示 loading)
  • startTransition:把里面的更新降级为低优先级

代码演示(立刻不卡)

js 复制代码
const [text, setText] = useState('')
const [list, setList] = useState([])

const [isPending, startTransition] = useTransition()

const onChange = (e) => {
  // 1. 高优先级:立即更新输入框
  setText(e.target.value)

  // 2. 低优先级:延迟执行大数据渲染
  startTransition(() => {
    setList(filterBigList(e.target.value))
  })
}

效果

输入框永远流畅!

大数据列表延迟一点点,完全不影响体验


二、useDeferredValue

作用

延迟一个值 ,等主线程空闲了,再更新这个值

适合:值来自父组件、无法用 startTransition 包裹

核心 API

js 复制代码
const deferredValue = useDeferredValue(value)

代码演示

js 复制代码
const [text, setText] = useState('')

// 让 text 延迟更新
const deferredText = useDeferredValue(text)

// 只有 deferredText 变了才执行耗性能操作
const list = useMemo(() => {
  return filterBigList(deferredText)
}, [deferredText])

效果

和 useTransition 一模一样

输入流畅,大数据延迟渲染


三、两者区别(超级好记)

方式 用法 适用场景
useTransition 包裹 setState 自己控制更新的地方
useDeferredValue 包裹一个值 子组件、无法控制 setState

一句话区分:

  • 控制更新函数 → useTransition
  • 控制一个值 → useDeferredValue

四、底层原理(面试必问)

React 18 并发渲染 能力:

  1. 把更新分为 高优先级 / 低优先级
  2. 高优先级(输入、点击)可中断低优先级
  3. 低优先级渲染会被暂停、插队、恢复
  4. 保证 UI 永远流畅

五、超级总结(背这个就够)

useTransition

  • 标记低优先级更新
  • 不阻塞输入、点击
  • 用法:startTransition(() => { 耗性能更新 })

useDeferredValue

  • 延迟一个
  • 等空闲再更新
  • 用法:const deferredVal = useDeferredValue(val)

共同目的

让耗性能的页面,不卡顿、不掉帧、保持流畅!


终极一句话

高优先级先走,低优先级等空闲 → 这就是 useTransition / useDeferredValue!


相关推荐
爱学习的程序媛2 小时前
【WebRTC】呼叫中心前端技术选型:SIP.js vs JsSIP vs Verto
前端·javascript·typescript·音视频·webrtc·实时音视频·web
Amumu121382 小时前
Js: ES新特性(一)
开发语言·前端·javascript
scofield_gyb2 小时前
Redis 6.2.7安装配置
前端·数据库·redis
木斯佳2 小时前
前端八股文面经大全: 蓝色光标前端一面OC(2026-03-23)·面经深度解析
前端·面试·vue·校招·js·面经
2301_792580002 小时前
Pyrocko + PSGRN/PSCMP小问题
前端
Highcharts.js2 小时前
Highcharts for Python|用 Pythonic 的方式构建AI数据可视化图表
前端·人工智能·python·信息可视化·数据科学·highcharts·ai可视化
是罐装可乐2 小时前
SPA首屏接口过多导致卡顿?一套前端请求调度方案彻底解决
前端·性能优化·spa·前端架构·请求队列
子豪-中国机器人2 小时前
python AI自动化
java·前端·python
JavaPub-rodert3 小时前
Codex GPT-5.4 使用教程(命令大全版)
前端·chrome·gpt·codex