react19新API之use()用法总结

server/2025/1/23 0:51:15/

React use() Hook 使用指南

概述

use() 是 React 19 引入的新 Hook,它允许你在组件内部直接使用 Promise、Context 和其他可订阅的值。它是一个更通用的数据获取和订阅机制。

基本语法

const value = use(resource);

主要用途

1. Promise 处理

function UserDetails({ userId }: { userId: string }) {const user = use(fetchUser(userId));// 如果 Promise 还未解决,组件会被挂起// 一旦 Promise resolved,组件会重新渲染return (<div><h2>{user.name}</h2><p>{user.email}</p></div>);
}

2. Context 使用

function Button() {const theme = use(ThemeContext);// 等同于 useContext(ThemeContext)return (<button className={theme.buttonClass}>Click me</button>);
}

3. 条件性使用

function DataView({ shouldFetch }: { shouldFetch: boolean }) {if (shouldFetch) {// use() 可以在条件语句中使用const data = use(fetchData());return <div>{data.content}</div>;}return <div>Not fetching</div>;
}

高级用法

1. 并行数据获取

function UserProfile({ userId }: { userId: string }) {const [user, posts, friends] = use(Promise.all([fetchUser(userId),fetchUserPosts(userId),fetchUserFriends(userId)]));return (<div><UserInfo user={user} /><PostList posts={posts} /><FriendList friends={friends} /></div>);
}

2. 嵌套组件中使用

function Comments({ postId }: { postId: string }) {return (<Suspense fallback={<Spinner />}><AsyncComments postId={postId} /></Suspense>);
}function AsyncComments({ postId }: { postId: string }) {const comments = use(fetchComments(postId));return (<ul>{comments.map(comment => (<CommentItem key={comment.id} comment={comment} />))}</ul>);
}

3. 自定义资源

function createResource<T>(promise: Promise<T>) {let status = 'pending';let result: T;let error: Error;const suspender = promise.then((data) => {status = 'success';result = data;},(err) => {status = 'error';error = err;});return {read() {switch (status) {case 'pending':throw suspender;case 'error':throw error;case 'success':return result;}}};
}function DataComponent() {const resource = useMemo(() => createResource(fetchData()), []);const data = use(resource);return <div>{data}</div>;
}

最佳实践

1. 错误边界处理

function ErrorBoundary({ children }: { children: React.ReactNode }) {return (<Suspense fallback={<Spinner />}><ErrorBoundaryInner>{children}</ErrorBoundaryInner></Suspense>);
}function DataComponent() {return (<ErrorBoundary><AsyncContent /></ErrorBoundary>);
}

2. 缓存和预加载

const cache = new Map();function fetchWithCache(key: string) {if (!cache.has(key)) {cache.set(key, fetchData(key));}return cache.get(key);
}function PreloadedData({ id }: { id: string }) {// 预加载数据const data = use(fetchWithCache(id));return <div>{data}</div>;
}

注意事项

  1. 使用限制:

    • 只能在组件内部使用
    • 需要配合 Suspense 使用
    • 不能在事件处理器中使用
  2. 性能考虑:

    • 合理使用缓存机制
    • 避免重复创建资源
    • 考虑数据预加载
  3. 错误处理:

    • 使用错误边界捕获异常
    • 提供合适的加载状态
    • 实现优雅的降级处理

总结

  1. use() 的优势:

    • 简化异步数据获取
    • 支持条件性使用
    • 更好的类型推断
    • 统一的资源使用方式
  2. 适用场景:

    • 数据获取
    • Context 消费
    • 自定义订阅
    • 并行数据加载
  3. 使用建议:

    • 配合 Suspense 使用
    • 实现适当的错误处理
    • 注意性能优化
    • 合理组织代码结构

http://www.ppmy.cn/server/160607.html

相关文章

Android开发,待办事项提醒App的设计与实现(个人中心页)

文章目录 1. 编写UI布局2. 实现逻辑3. 运行效果图3. 关于作者其它项目视频教程介绍 Android开发&#xff0c;待办事项提醒App的设计与实现&#xff1a; https://blog.csdn.net/jky_yihuangxing/article/details/145277956?spm1001.2014.3001.5501 1. 编写UI布局 fragment_mi…

Java后端Controller参数校验的一些干货及问题~

你们好,我是金金金。 场景 先看如下一张图,这是一个控制器里面的一个方法,第一眼是不是就感觉代码量非常多?而且随着参数越来越多 你则需要写n个if else来完成校验,属实是麻烦而且不够优雅 JSR303校验 仔细认真看,更容易理解吸收,想想什么层面需要做校验呢? 前端请求后…

【漫话机器学习系列】053.梯度爆炸(Exploding Gradient Problem)

梯度爆炸&#xff08;Exploding Gradient Problem&#xff09; 定义 梯度爆炸是指在深度神经网络的训练过程中&#xff0c;由于梯度的值在反向传播时不断累积&#xff0c;导致梯度变得非常大&#xff0c;以至于模型无法正常学习。这种现象在深层网络或循环神经网络&#xff0…

Hadoop集群搭建

1. 安装并配置虚拟机 这里基于VmWare来去构建三台虚拟机 我已经有了一台模板虚拟机&#xff0c;所以基于该模板虚拟机进行完整克隆得到三台机器&#xff0c;分别是hadoop1、hadoop2、hadoop3 修改主机名称 # hadoop1的主机名称修改为hadoop1&#xff0c;以此类推 vim /etc/ho…

4.C++中的循环语句

C中的循环语句 for 循环 for 循环是一种最常用的循环结构&#xff0c;通常用于已知循环次数的情况。 基本语法&#xff1a; for (初始化表达式; 条件表达式; 更新表达式) {// 循环体&#xff0c;当条件表达式为真时执行 }例如&#xff1a; #include <iostream> usin…

数据库存储上下标符号,sqlserver 2008r2,dm8

sqlserver 2008r2&#xff1a; 数据类型需要用nvarchar插入数据时字符串前需要用N create table test( col1 varchar(50), col2 nvarchar(50) ) insert into test(col1,col2) values(U⁴⁵⁶⁷⁸⁹⁰D₁₂₃₄₅₆₇₈₉₀,U⁴⁵⁶⁷⁸⁹⁰D₁₂₃₄₅₆₇₈₉₀) insert into…

如何用AI智能生成PPT,提升工作效率和创意

如何用AI智能生成PPT&#xff0c;提升工作效率和创意&#xff01;在这个信息爆炸的时代&#xff0c;我们每个人的时间都变得尤为珍贵&#xff0c;尤其是在繁忙的工作中&#xff0c;如何更高效地完成任务变得至关重要。制作PPT往往让人既头痛又心烦。面对大量的内容整理和设计&a…

【Vim Masterclass 笔记24】S10L43 + L44:同步练习10 —— 基于 Vim 缓冲区的各类基础操作练习(含点评课)

文章目录 S10L43 Exercise 12 - Vim Buffers1 训练目标2 操作指令2.1. 打开 buf* 文件2.2. 查看缓冲区 View the buffers2.3. 切换缓冲区 Switch buffers2.4. 同时编辑多个缓冲区 Edit multiple buffers at once2.5. 缓冲区的增删操作 Add and delete buffers2.6. 练习 Vim 内置…