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!


相关推荐
destinying7 小时前
前端秒变AI全栈,我的核心资产是一套Node.js“中间件”
前端·后端·面试
环信7 小时前
即时通讯服务的数据安全与合规实践
前端
轻闲一号机8 小时前
【语音】笔记
前端·笔记·算法
初心丨哈士奇8 小时前
一行 # 的差别:彻底搞懂前端路由的 hash 和 history 模式
前端·浏览器
羊羊小栈8 小时前
非物质文化宣传系统(基于前后端Web开发)
前端·人工智能·毕业设计·大作业
环信8 小时前
从SLA到弱网对抗-环信即时通讯云的可靠性工程
前端
半个落月8 小时前
前端工程化第一步:BEM 国际命名规范与 CSS Reset 实战
前端·css
kyriewen8 小时前
开源|Image Harvest v1.0.5:AI 智能标签 + Eagle 导出,设计师和开发者的图片工作流神器
前端·javascript·ai编程
wuhen_n8 小时前
LangChain Memory 详解:实现 AI 连续对话不丢失上下文
前端·langchain·ai编程
wuhen_n8 小时前
LangChain Function Call 实战:让 AI 调用自定义工具
前端·langchain·ai编程