React 中hooks之useDeferredValue用法总结

目录

  1. 概述
  2. 基本用法
  3. 与防抖节流的区别
  4. 使用场景
  5. 区分过时内容
  6. 最佳实践

概述

什么是 useDeferredValue?

useDeferredValue 是 React 18 引入的新 Hook,用于延迟更新某个不那么重要的部分。它接收一个值并返回该值的新副本,新副本会延迟更新。这种延迟是有益的,让紧急更新(如用户输入)优先于不紧急的更新(如渲染搜索结果列表)。

主要特点

  • 自动处理延迟
  • 与 Suspense 集成
  • 不会像防抖和useTransition那样丢弃中间值
  • 可以区分过时/最新内容

基本用法

1. 基本语法

import { useDeferredValue } from 'react';function SearchResults() {const [query, setQuery] = useState('');const deferredQuery = useDeferredValue(query);return (<div><input value={query} onChange={e => setQuery(e.target.value)} /><SlowList query={deferredQuery} /> {/* 使用延迟值进行渲染 */}</div>);
}

2. 区分过时内容示例

function SearchResults() {const [query, setQuery] = useState('');const deferredQuery = useDeferredValue(query);const isStale = query !== deferredQuery; // 判断内容是否过时return (<div><input value={query} onChange={e => setQuery(e.target.value)} /><div style={{ opacity: isStale ? 0.8 : 1,transition: 'opacity 0.2s ease'}}><SlowList query={deferredQuery} /></div>{isStale && <div>Loading new results...</div>}</div>);
}

与防抖节流的区别

1. 防抖 (Debounce)

// 防抖示例
function SearchWithDebounce() {const [query, setQuery] = useState('');const debouncedSearch = useCallback(debounce((value) => {// 执行搜索performSearch(value);}, 500),[]);// 会丢弃中间值,只处理最后一次输入return (<input onChange={e => {setQuery(e.target.value);debouncedSearch(e.target.value);}} />);
}

2. 节流 (Throttle)

// 节流示例
function SearchWithThrottle() {const [query, setQuery] = useState('');const throttledSearch = useCallback(throttle((value) => {performSearch(value);}, 100),[]);// 固定时间间隔执行,可能会延迟响应return (<input onChange={e => {setQuery(e.target.value);throttledSearch(e.target.value);}} />);
}

3. useDeferredValue

// useDeferredValue 示例
function SearchWithDeferred() {const [query, setQuery] = useState('');const deferredQuery = useDeferredValue(query);// React 会根据用户设备性能和当前 CPU 负载自动调整延迟// 不会丢弃任何值,而是以较低优先级处理它们return (<><input onChange={e => setQuery(e.target.value)} /><SlowList query={deferredQuery} /></>);
}

使用场景

1. 大列表渲染

function VirtualizedList({ items }) {const [filter, setFilter] = useState('');const deferredFilter = useDeferredValue(filter);const isStale = filter !== deferredFilter;const filteredItems = useMemo(() => items.filter(item => item.includes(deferredFilter)),[deferredFilter, items]);return (<div><input value={filter} onChange={e => setFilter(e.target.value)} /><div style={{ opacity: isStale ? 0.8 : 1 }}>{filteredItems.map(item => (<ListItem key={item} item={item} />))}</div></div>);
}

2. 实时预览

function MarkdownEditor() {const [text, setText] = useState('');const deferredText = useDeferredValue(text);const isStale = text !== deferredText;return (<div className="editor"><textareavalue={text}onChange={e => setText(e.target.value)}/><div className={`preview ${isStale ? 'stale' : ''}`}><MarkdownPreview text={deferredText} /></div></div>);
}

最佳实践

  1. 合理使用 useMemo
function SlowList({ text }) {const deferredText = useDeferredValue(text);const isStale = text !== deferredText;// 使用 useMemo 避免不必要的重新计算const items = useMemo(() => computeExpensiveList(deferredText),[deferredText]);return (<div style={{ opacity: isStale ? 0.8 : 1 }}>{items.map(item => (<ListItem key={item.id} item={item} />))}</div>);
}
  1. 优雅降级处理
function SearchResults({ query }) {const deferredQuery = useDeferredValue(query);const isStale = query !== deferredQuery;return (<div>{isStale && (<div className="stale-indicator">Showing results for "{deferredQuery}"<br />Updating results for "{query}"...</div>)}<ResultsList query={deferredQuery} /></div>);
}

总结

  1. useDeferredValue vs 防抖/节流:

    • useDeferredValue 不会丢弃更新
    • 自动适应用户设备性能
    • 与 React 并发特性集成
    • 提供过时状态标识
  2. 适用场景:

    • 大数据列表渲染
    • 实时预览功能
    • 复杂图表更新
    • 搜索建议
  3. 最佳实践:

    • 配合 useMemo 使用
    • 提供加载状态反馈
    • 合理处理过时内容
    • 注意性能优化
      在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/68663.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS 性能优化:实战案例分享

摘要&#xff1a; 本文将深入探讨 iOS 性能优化的重要性&#xff0c;并通过一系列实际开发案例&#xff0c;展示如何解决常见的性能问题&#xff0c;包括内存管理、CPU 性能、网络性能、UI 性能和启动性能等方面的优化&#xff0c;帮助 iOS 开发者打造更流畅、高效的应用程序。…

TMC2208替代A4988

前言 TMC2208 是一款先进的 1 轴步进驱动器&#xff0c;支持 stealthChop ™和 256 微步。本应用说明介绍了如何设置 TMC2208 以替代 A4988&#xff08;传统模式&#xff09;。 引脚比较 与其他电机驱动器相比&#xff0c;TMC2208 具有附加功能&#xff1a;256 微步。 自动…

二十三种设计模式-代理模式

一、定义与核心思想 代理模式是一种结构型设计模式&#xff0c;其核心思想是提供一个代理对象&#xff0c;用以控制对实际对象的访问。通过代理对象&#xff0c;可以在不改变实际对象的情况下&#xff0c;添加各种功能&#xff0c;如权限控制、懒加载、缓存、远程调用等。 二…

SQL刷题快速入门(三)

其他章节&#xff1a; SQL刷题快速入门&#xff08;一&#xff09; SQL刷题快速入门&#xff08;二&#xff09; 承接前两个章节&#xff0c;本系列第三章节主要讲SQL中where和having的作用和区别、 GROUP BY和ORDER BY作用和区别、表与表之间的连接操作&#xff08;重点&…

ComfyUI 矩阵测试指南:用三种方法,速优项目效果

在ComfyUI中&#xff0c;矩阵测试也叫xyz图表测试&#xff0c;作用是通过控制变量的方式来对Lora模型以及各种参数开展测试&#xff0c;并进行有效区分。其中测试方法有很多种&#xff0c;可以通过借助插件也可以自行搭建工作流实现&#xff0c;下面介绍3种方式&#xff1a; 1…

在stm32中C语言编写的程序中,一个整形数据是怎么存储的,高位在前还是低位在前

目录 举个例子 如何验证 小结 在 STM32&#xff08;基于 ARM Cortex-M 架构&#xff09;的系统中&#xff0c;默认是小端&#xff08;Little Endian&#xff09; 存储方式。也就是说&#xff0c;对于一个整型&#xff08;例如 32 位 int&#xff09;&#xff0c;它的最低有效…

图数据库 | 19、高可用分布式设计(下)

相信大家对分布式系统设计与实现的复杂性已经有了一定的了解&#xff0c;本篇文章对分布式图数据库系统中最复杂的一类系统架构设计进行探索&#xff0c;即水平分布式图数据库系统&#xff08;这个挑战也可以泛化为水平分布式图数据仓库、图湖泊、图中台或任何其他依赖图存储、…

基于Python的多元医疗知识图谱构建与应用研究(上)

一、引言 1.1 研究背景与意义 在当今数智化时代,医疗数据呈爆发式增长,如何高效管理和利用这些数据,成为提升医疗服务质量的关键。传统医疗数据管理方式存在数据孤岛、信息整合困难等问题,难以满足现代医疗对精准诊断和个性化治疗的需求。知识图谱作为一种知识表示和管理…

Visual Studio Code + Stm32 (IAR)

记录一下&#xff0c; 以前看别人在 vsc 下配置 stm32 工程非常麻烦。 最近&#xff0c;突然发现&#xff0c; iar 官方出了两个插件&#xff0c; iar build 、 iar C-Spy 安装之后&#xff0c;配置一下 iar 软件路径。 然后&#xff0c;直接打开工程目录&#xff0c;编译…

oracle之行转列

对于Oracle的行转列功能一直云里雾里&#xff0c;马马虎虎&#xff0c;对行转列的使用场景和使用方法都不够深刻&#xff0c;最近有空理解一下。 Oracle 11g后有专门的函数pivot&#xff0c;对于特定的场景可以直接套用。 需求&#xff1a;求各份job不同员工工资是多少&#xf…

【Linux】Linux入门(4)其他常用指令

目录 软件安装yum命令 systemctl命令软链接IP地址和主机名特殊IP地址主机名域名解析 网络请求和下载ping命令wget命令curl命令 端口nmap指令 进程管理ps命令 查看进程kill 关闭进程 主机状态top命令 查看系统资源占用 软件安装 操作系统安装软件有许多种方式&#xff0c;一般分…

B站评论系统的多级存储架构

以下文章来源于哔哩哔哩技术 &#xff0c;作者业务 哔哩哔哩技术. 提供B站相关技术的介绍和讲解 1. 背景 评论是 B站生态的重要组成部分&#xff0c;涵盖了 UP 主与用户的互动、平台内容的推荐与优化、社区文化建设以及用户情感满足。B站的评论区不仅是用户互动的核心场所&…

蓝桥杯 阶乘的和(C++完整代码+详细分析)

题目描述 原题链接 阶乘的和 问题描述 给定 n 个数 Ai​&#xff0c;问能满足 m! 为 ∑(Ai!) 的因数的最大的 m 是多少。其中 m! 表示 m 的阶乘&#xff0c;即 123⋯m。 输入格式 输入的第一行包含一个整数 n。 第二行包含 n 个整数&#xff0c;分别表示 Ai​&#xff0c;相…

2024:成长、创作与平衡的年度全景回顾

文章目录 1.前言2.突破自我&#xff1a;2024年个人成长与关键突破3.创作历程&#xff1a;从构想到落笔&#xff0c;2024年的文字旅程4.生活与学业的双重奏&#xff1a;如何平衡博客事业与个人生活5.每一步都是前行&#xff1a;2024年度的挑战与收获6.总结 1.前言 回首2024年&a…

统信V20 1070e X86系统编译安装mysql-5.7.44版本以及主从构建

设备信息 操作系统版本架构CPU内存备注统信UOS V20 1070eX864C8G此配置仅做编译安装验证&#xff0c;持续运行或数据量增长大请自行评估资源配置。统信UOS V20 1070eX864C8G 资源包 该包包含mysql-5.7.44源码包、boost资源包、统信编译mysql-5.7.44安装包 通过网盘分享的文件…

4 AXI USER IP

前言 使用AXI Interface封装IP&#xff0c;并使用AXI Interface实现对IP内部寄存器进行读写实现控制LED的demo&#xff0c;这个demo是非常必要的&#xff0c;因为在前面的笔记中基本都需哟PS端与PL端就行通信互相交互&#xff0c;在PL端可以通过中断的形式来告知PS端一些事情&…

RoCE网络及其协议栈详解(没有中间商赚差价的网络)

引言 随着数据中心对高性能、低延迟通信需求的不断增长&#xff0c;传统的TCP/IP以太网连接已经难以满足现代应用的要求。为了解决这些问题&#xff0c;RDMA&#xff08;Remote Direct Memory Access&#xff09;技术应运而生。RDMA是一种允许网络中的不同计算机直接访问对方内…

回归预测 | MATLAB基于TCN-BiGRU时间卷积神经网络结合双向门控循环单元多输入单输出回归预测

效果一览 基本介绍 回归预测 | MATLAB基于TCN-BiGRU时间卷积神经网络结合双向门控循环单元多输入单输出回归预测 一、引言 1.1、研究背景及意义 在当今数据驱动的时代&#xff0c;时间序列预测已成为金融、气象、工业控制等多个领域的关键技术。随着人工智能和机器学习技术的…

HTML<img>标签

例子 如何插入图片&#xff1a; <img src"img_girl.jpg" alt"Girl in a jacket" width"500" height"600"> 下面有更多“自己尝试”的示例。 定义和用法 该<img>标签用于在 HTML 页面中嵌入图像。 从技术上讲&#x…

Linux--运维

Mysql主从同步 通过将MySQL的某一台主机&#xff08;master&#xff09;的数据复制到其他主机&#xff08;slaves&#xff09;上&#xff0c;并重新执行一遍来执行 复制过程中一台服务器充当主服务器&#xff0c;而其他一个或多个其他服务器充当从服务器 为什么要做主从复制 …