0

0

React 中的异步派生

花韻仙語

花韻仙語

发布时间:2024-11-07 14:40:01

|

486人浏览过

|

来源于dev.to

转载

react 中的异步派生

我们遇到了一个问题,异步很难。

假设您有一个简单的 get api,一个接收 searchtext 作为参数的搜索。您使用您偏好的 http 请求工具调用它并得到一个承诺,它解析为您正在搜索的任何内容的列表。

如何在 react 组件中调用它?

首先,需要注意一件事,我所描述的可以建模为:

result = await searchapi(searchtext);

让我们在这里了解一下概念。 这是一个推导。对于每个版本的 searchtext,您可以获得不同的结果。但这里有一些问题:

  • 这是外部数据。
  • 它返回一个承诺。

如何在 react 中将其称为派生?

使用第三方库,例如 tanstack query 和 swr 解决了我们的问题。它们为我们提供了可以在 react 组件中使用的钩子,接收我们的状态和属性,并在 api 发生变化时重新计算(重新获取)。看这个例子:

const { data: searchresult, loading } = usequery({querykey: [search, searchtext],queryfn: getsearch,});

好的,我们解决了异步推导,对吧?

其实不是。

顺便说一句,我总是建议只使用这些库之一,它们非常棒,并且可以在更复杂的情况下节省大量时间(例如重新获取、重试、缓存控制等),但我们不能指望第三个- 解决 react 概念问题的聚会。

再次回到反应性,我们需要有一种方法来处理派生模型中的异步情况。 react 应该为我们提供一个针对这种情况的原语。嗯,直到版本 18 之前我们都没有它,但在版本 19 中就不同了。

“使用”案例

react 19 引入了一个名为 use 的新原语。是的,命名有点令人困惑,但它在 react 反应模型中的作用非常重要。有了它,我们可以在组件渲染期间解决承诺。 缺失的推导。

阿里云AI平台
阿里云AI平台

阿里云AI平台

下载

在此之前,在组件渲染期间调用 fetch 的唯一方法是使用 useeffect,调用 promise 并在 then 子句中,使用作为响应的值设置状态。这在某种程度上是有效的,但我们在使用效果来实现这一点时遇到了所有问题。
use 原语允许我们在组件渲染期间解析 promise,允许我们使用状态和 props 来创建 promise,然后解析这些 promise 并将其用于我们的函数和 jsx。

const useCountTotal = (count: number) => {
  const countTotalPromise = useMemo(() => genericPromise(count), [count]);


  const result = use(countTotalPromise);


  return result;
}


function AsyncDerivation({count}: { count: number}) {
  const result = useCountTotal(count);

  return (
    <div>Total count is: {result}</div>
  )
}

在我写这篇文章的时候,我们还没有 react 19 的最终版本。有一些警告,并且该原语可能会在未来发展以在更多地方工作。

原始使用的一个具体问题是它需要与 suspense 一起使用,这是有充分理由的。

异步和 react 组件

await 的概念很好,但是与 react 组件结合时有一个缺陷。您不能只在渲染期间使用await。 react 调用组件来获取 jsx 响应,并在流程中使用它来渲染 ui。

如果我们可以在等待中停止所有事情,react 就无法访问该组件的子组件并继续其工作,直到树的末尾。我们会停止渲染流程并使 ui 不更新并冻结。

如何解决?

我们可以看一下我在本文中使用的两个示例。第一个采用返回标志(例如加载)的方法,而不是阻塞渲染流。当承诺得到解决时,它会引发重新渲染,更新标志,加载变为 false 并且数据接收响应数据。

使用方式不同。它的行为确实类似于await原语,因此组件渲染流在那里停止,直到分辨率。

等等,等等,你说这是一个问题,对吧?

拯救悬念来了。当您使用 use 原语时,它将被包装在 suspense 组件中,渲染流将停止等待 use 分辨率,并且用户将获得在 ui 上渲染的后备(通常是加载旋转器或骨架,表明我们正在那里加载一些东西)。

当使用承诺得到解决后,我们将继续渲染并相应地更新 ui。无需使用useeffect。

结论

use 原语对于旨在使用 suspense 并处理异步行为的库作者来说非常有用。对于应用程序开发人员来说,它修复了基本反应性模型中的另一种情况,这非常适合简单的用例。由于它封装了 promise,因此它不仅限于 http 请求,还适用于所有异步情况和外部 api 使用,这可以为生态系统添加更多资源。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

337

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

429

2023.10.12

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

497

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

452

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

3598

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2917

2024.08.16

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

136

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

47

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号