React

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > React > react useDeferredvalue和useTransition

react useDeferredvalue和useTransition的实现

作者:英俊潇洒美少年

本文主要介绍了react useDeferredvalue和useTransition的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

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

一句话核心结论

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

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

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

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

const [isPending, startTransition] = useTransition()

代码演示(立刻不卡)

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

const deferredValue = useDeferredValue(value)

代码演示

const [text, setText] = useState('')

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

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

效果

和 useTransition 一模一样!
输入流畅,大数据延迟渲染

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

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

一句话区分:

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

React 18 并发渲染 能力:

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

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

useTransition

useDeferredValue

共同目的

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

终极一句话

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

到此这篇关于react useDeferredvalue和useTransition的实现的文章就介绍到这了,更多相关react useDeferredvalue和useTransition内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文