React useTransition

useTransition 是 React 18 中引入的新 Hook,它是并发模式(Concurrent Mode)功能的一部分。useTransition 允许你告诉 React 某些更新具有较低的优先级,React 可以在浏览器空闲时才去处理这些更新。这可以帮助提高应用的响应性,特别是在执行大型更新或密集型计算时。

作用:

useTransition 的主要作用是让你能够区分高优先级更新与低优先级更新。高优先级的更新(如用户输入)会立即执行,而低优先级的更新(如过滤列表、加载数据等)可以稍后执行,从而保持应用界面的流畅。

用法:

useTransition 返回一个数组,其中包含两个元素:

  1. startTransition 函数,你可以用它来触发低优先级的更新。
  2. isPending 状态,它是一个布尔值,表示是否有低优先级更新正在等待执行。
scss 复制代码
const [isPending, startTransition] = useTransition();

示例:

下面是一个使用 useTransition 的示例,展示了如何在过滤列表时保持界面的响应性:

javascript 复制代码
import React, { useState, useTransition } from 'react';

function FilteredList() {
  const [input, setInput] = useState('');
  const [list, setList] = useState(items); // 假设 items 是列表项数组

  // 使用 useTransition Hook
  const [isPending, startTransition] = useTransition();

  function handleInputChange(e) {
    const nextInput = e.target.value;
    setInput(nextInput);

    // 使用 startTransition 来执行低优先级的更新
    startTransition(() => {
      const filteredItems = items.filter(item => 
        item.includes(nextInput)
      );
      setList(filteredItems);
    });
  }

  return (
    <>
      <input type="text" value={input} onChange={handleInputChange} />
      {isPending ? <span>Loading...</span> : null}
      <ul>
        {list.map(item => (
          <li key={item}>{item}</li>
        ))}
      </ul>
    </>
  );
}

使用注意事项:

  1. UI 指示 :由于低优先级的更新可能会延迟执行,建议使用 isPending 状态来向用户显示一些加载指示,如加载旋转器或进度条,以改善用户体验。
  2. 不要滥用useTransition 非常适合处理可能会导致长时间渲染的更新,但不是每个状态更新都需要用 useTransition 包裹。过度使用可能会导致不必要的复杂性。
  3. 确保 React 版本useTransition 是 React 18 的新功能,需要确保你使用的是支持 Concurrent Mode 的 React 版本。
  4. 并发模式useTransition 旨在与并发模式一起使用,在这种模式下,React 可以打断、暂停和恢复渲染工作。确保你的应用已启用并发模式。

useTransition 提供了一种优雅的方式来处理在用户界面中可能导致性能问题的复杂或密集型任务,帮助开发者提升应用的响应性和用户体验。

相关推荐
hj5914_前端新手2 小时前
javascript基础- 函数中 this 指向、call、apply、bind
前端·javascript
薛定谔的算法2 小时前
低代码编辑器项目设计与实现:以JSON为核心的数据驱动架构
前端·react.js·前端框架
Hilaku2 小时前
都2025年了,我们还有必要为了兼容性,去写那么多polyfill吗?
前端·javascript·css
yangcode2 小时前
iOS 苹果内购 Storekit 2
前端
LuckySusu2 小时前
【js篇】JavaScript 原型修改 vs 重写:深入理解 constructor的指向问题
前端·javascript
LuckySusu2 小时前
【js篇】如何准确获取对象自身的属性?hasOwnProperty深度解析
前端·javascript
LuckySusu2 小时前
【js篇】深入理解 JavaScript 作用域与作用域链
前端·javascript
LuckySusu3 小时前
【js篇】call() 与 apply()深度对比
前端·javascript
LuckySusu3 小时前
【js篇】addEventListener()方法的参数和使用
前端·javascript
该用户已不存在3 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net