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 反应模型中的作用非常重要。有了它,我们可以在组件渲染期间解决承诺。 缺失的推导。

DM建站系统汽车保养维修HTML5网站模板1.5
DM建站系统汽车保养维修HTML5网站模板1.5

DM建站系统汽车保养维修HTML5网站模板,DM企业建站系统。是由php+mysql开发的一套专门用于中小企业网站建设的开源cms。DM系统的理念就是组装,把模板和区块组装起来,产生不同的网站效果。可以用来快速建设一个响应式的企业网站( PC,手机,微信都可以访问)。后台操作简单,维护方便。DM企业建站系统安装步骤:第一步,先用phpmyadmin导入sql文件。 第二步:把文件放到你的本地服务器

下载

在此之前,在组件渲染期间调用 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 (
    
Total count is: {result}
) }

在我写这篇文章的时候,我们还没有 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 使用,这可以为生态系统添加更多资源。

相关专题

更多
promise的用法
promise的用法

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

303

2023.10.12

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

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

401

2023.10.12

http500解决方法
http500解决方法

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

395

2023.11.09

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

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

416

2023.11.14

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

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

2087

2024.03.12

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

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

2057

2024.08.16

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

31

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

119

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号