在 React 中获取数据的6种方法

一、前言

数据获取是任何 react 应用程序的核心方面。对于 React 开发人员来说,了解不同的数据获取方法以及哪些用例最适合他们很重要。

但首先,让我们了解 JavaScript Promises。

简而言之,promise 是一个 JavaScript 对象,它将在未来的某个时间产生一个值。这通常适用于异步操作(例如数据获取)。

Promises具有三种状态:

  • Pending:承诺仍在进行中的地方
  • Fulfilled:承诺成功解决并返回值的地方
  • Rejected:承诺因错误而失败

如果一个promise被Fulfilled或Rejected,它就被解决了。Promise 有不同的方法来根据结果做不同的事情。下一节将更详细地讨论这些方法。

二、使用 Promise 方法获取 api

Fetch API 提供了一个全局的 fetch() 方法,使开发人员能够以直接的方式获取数据。在 fetch() 之前,传统方法是使用 XMLHttpRequest()。(本文不涉及此方法,因为 fetch() 已被更强大、更灵活的功能集所取代。)

fetch() 方法接受一个参数,即要请求的 URL,并返回一个promise。第二个可选参数options 是一个属性数组。fetch() 的返回值可以是 JSON 或 XML(对象数组或单个对象)。如果没有选项参数,fetch() 将始终发出 GET 请求。

第一种方法是您通常会在简单的数据获取用例中看到的方法,并且通常是浏览 API 文档时的第一个结果。

如前所述,我们从返回狗的随机图像的 API 获取数据,并将该图像呈现在屏幕上。在发出请求之前,我们将代码包装在一个带有空依赖项数组的 useEffecthook 中,以便 fetch() 方法仅在组件最初安装时运行。

useEffect(() => {
    fetch(URL)
      // syntax for handling promises
      .then((res) => {
        // check to see if response is okay
        if (res.ok) {
          // if okay, take JSON and parse to JavaScript object
          return res.json();
        }
        throw res;
      })
      //  .json() returns a promise as well
      .then((data) => {
        console.log(data);
        // setting response as the data state
        setData(data);
      })
      // if res is not okay the res is thrown here for error
      .catch((err) => {
        console.error(`Error: ${err}`);
        // setting the error state
        setError(err);
      })
      //  regardless if promise resolves successfully or not we remove loading state
      .finally(() => {
        setLoading ( false );
      });
  }, []);

在上例中,我们调用该方法并传入 API 端点的 URL。在这个方法中,我们使用 promise 对象的方法(回想一下返回一个 promise)。

我们使用这个方法并传入一个回调函数来检查响应是否正常。如果响应正常,我们将获取返回的 JSON 数据并使用该方法将其解析为 JavaScript 对象。如果响应不正常,我们就会报错。

由于 .json() 方法也返回一个承诺,我们可以链接另一个 .then() 并传递一个函数来设置数据的状态,然后在组件的其他地方使用。在我们的示例中,外部 API 返回一个具有 url 属性的对象(它将用作 srcour 图像)。

继续通过链,下一部分是 .catch() 以安排在承诺被拒绝时调用的函数。这也返回另一个承诺,然后我们可以链接 .finally() 无论承诺是否已解决(解决或拒绝),它都会被调用。

这种 .finally() 方法使我们能够避免在 .then() 和 .catch() 中重复代码,使其成为我们示例中删除加载状态的好地方。

三、带有 Promise 方法的库 Axios

Axios 是一个流行的 HTTP 客户端库,用于高效的数据获取。它可以通过 npm 或其他包管理器轻松安装到 React 应用程序中。使用 Axios 是 Fetch API 的替代方法,如果您不介意安装外部库,它有一些优势。

第二个示例将非常接近第一个示例的代码,使用相同的 promise 方法来处理 promise 状态和响应。

在 fetch() 将 Axios 库导入我们的组件之后,我们可以使用 axios.get() 一种可以将 URL 传递到我们的外部 API 端点的方法。

这将返回一个 Promise,因此我们可以采用与 Promise 方法链接相同的方法。

useEffect(() => {
    axios.get(URL)
      // syntax for handling promises
      .then((res) => {
        console.log(res.data);
        // axios converts json to object for us (shortens our code)
        setData(res.data);
      })
      // axios takes care of error handling for us instead of checking manually
      .catch((err) => {
        console.error(`Error: ${err}`);
        // setting the error state
        setError(err);
      })
      //  regardless if promise resolves successfully or not we remove loading state
      .finally(() => {
        setLoading ( false );
      });
  }, []);

Fetch API 的代码与此 Axios 方法之间的明显区别在于,使用 Axios 我们只需要一个,因为 Axios 为我们将 .then()JSON 转换为 JavaScript 对象(缩短了我们的代码)。

另外,我们不再写条件来手动抛出错误,因为axios会为你抛出400和500范围的错误(再次缩短我们的代码)。

四、异步函数(async/await)

在此示例中,我们将放弃在前两个示例中使用的承诺链,而是引入一种更现代的方法来编写异步的、基于承诺的代码。

这种方法可以与您选择的任何抓取机制一起使用,但对于本示例,我们将坚持使用 Axios 库。

第三个示例与前一个示例类似的方式设置组件,方法是导入 Axios 库,然后使用一个空的 dependencies 数组包装用于在 useEffecta 中获取数据的代码。

在 useEffect 中,我们使用关键字 async 创建一个异步函数,然后在该函数中我们有三个独立的部分 - try、catch 和 finally。

这种 try/catch 方法用于处理 JavaScript 中的错误。try块内的代码首先被执行,如果抛出任何错误,它们将被“捕获”在块中,catch并执行内部代码。

最后,finallyblock 将始终在流通过 try/catch 之后执行。

useEffect(() => {
    // create async function b/c cannot use async in useEffect arg cb
    const fetchData = async () => {
    //   with async/await use the try catch block syntax for handling
      try {
        // using await to make async code look sync and shorten 
        const res = await axios.get(URL);
        setData(res.data);
      } catch (err) {
        console.error(`Error: ${err}`);
        // setting the error state
        setError(err);
      } finally {
        setLoading ( false );
      }
    };


    fetchData ();
  }, []);

在此示例中,try 块创建了一个名为 res(response 的缩写)的变量,该变量使用 async 关键字。这允许代码看起来同步(更短,更容易在眼睛上)。

在此示例中,axios.get(URL) 正在“等待”直到它稳定下来。如果承诺得到履行,那么我们将数据设置为状态。如果承诺被拒绝(抛出错误),它会进入 catch 块。

五、创建一个“useFetch”自定义 React Hook

第四种方法是创建我们自己的自定义 React 钩子,调用 useFetchit 可以在我们应用程序的不同组件中重复使用,并从每个组件中删除笨重的获取代码。

这个例子实际上只是采用第四个例子(使用 Axios 库和 async/await 的相同技术)并将该代码移动到它自己的自定义钩子中。

为此,我们创建了一个名为 useFetch.js 的函数。然后我们使用 Effect 将前面示例中的所有代码以及我们正在跟踪的不同状态添加到函数 useFetch 中。

最后,这个函数将返回一个包含每个状态的对象,然后在调用钩子的地方使用 useFetchaccessed。我们的 useFetchhook 还将接受一个参数,即 URL ,以允许更多的可重用性和向不同端点发出提取请求的可能性。

const useFetch = (url) => {
  const [data, setData] = useState(null);
  const [ loading , setLoading ] =  useState ( true );
  const [error, setError] = useState(null);


  useEffect(() => {
    // create async function b/c cannot use asyc in useEffect arg cb
    const fetchData = async () => {
      //   with async/await use the try catch block syntax for handling
      try {
        // using await to make async code look sync and shorten
        const res = await axios.get(url);
        setData(res.data);
      } catch (err) {
        console.error(`Error: ${err}`);
        // setting the error state
        setError(err);
      } finally {
        setLoading ( false );
      }
    };


    fetchData ();
  }, []);


  return {
    data,
    loading,
    error,
  };
};

最后,我们将这个新的自定义钩子导入到将使用它的组件中,并像调用任何其他 React 钩子一样调用它。如您所见,这极大地提高了代码的可读性并缩短了我们的组件。

这种方法的最后一点是您还可以安装外部库而不是创建您自己的自定义挂钩。一个流行的库 react-fetch-hook 与我们刚刚构建的钩子具有非常相似的功能。

六、React 查询库

在 React 中获取数据的最现代和最强大的方法之一是使用 React Query 库。除了简单的数据获取之外,它还有许多功能,但是对于这个例子,我们将学习如何从同一个示例外部 API 中简单地获取数据。

安装和导入后,React Query 提供了许多自定义挂钩,可以以非常干净的方式在我们的组件中重复使用。

在此示例中,我们从中导入 QueryClient,然后使用提供程序包装我们的应用程序,并将 QueryClientProvider 实例作为属性传递给包装器。

这使我们能够在我们的应用程序中使用该库。

为了发出这个简单的 GET 请求,我们导入并使用了 useQueryhooks。与前面使用自定义挂钩的示例不同,我们传入了两个参数。

第一个必需参数是 queryKey ,用作此特定查询的参考键。

第二个必需参数是 queryFn ,它是查询将用于请求数据的函数。

我们将使用此查询函数,然后使用 Fetch API 和 promise 方法语法进行初始提取,而不是像我们之前的自定义挂钩示例中那样只传递一个简单的 URL。(这个钩子有许多其他可选参数。)

const { isLoading, error, data } = useQuery("dogData", () => fetch(URL).then((res) => res.json()));

isLoading 从这里开始,React Query 将在幕后完成所有额外的工作,在这种情况下,我们可以从这个钩子调用 destructure 、 error 和 use data in our application,尽管我们也可以访问许多其他值。

在比我们当前的 Dog Image API 示例更大的示例中,使用 React Query 的力量和优势是显而易见的。需要提及的一些附加功能包括:缓存、在后台更新“陈旧”数据以及其他与性能相关的优势。

七、Redux 工具包 RTK 查询

本文最后一种方法是使用Redux Toolkit的RTK Query进行数据采集。应用程序使用 Redux 进行状态管理是很常见的。

如果您的公司或您当前的副项目目前正在使用 Redux,一个不错的选择是使用 RTK 查询来获取数据,因为它提供了与 React 查询类似的简单性和优势。

要在存储 Redux 代码的任何地方开始使用 RTK 查询,请创建一个 rtkQueryService.js 文件来设置数据获取。

创建后,您将服务添加到您的 Redux 商店,假设您已经在使用 Redux,您将已经拥有一个包含您的应用程序的 <Provider>store 组件。

从这里开始,它与使用带有 React Query 方法的自定义钩子非常相似,您导入然后使用查询钩子并解构数据,错误然后是 Loading 可以在您的组件中使用。

const { data, error, isLoading } = useGetDogQuery();

如您所见,Redux 有很多设置,因此这可能不是我们用例的最佳方法,但如果您已经在 React 应用程序中使用 Redux 并且想要一种简单而现代的获取数据的方式,RTK 查询 可能很棒很有价值,这也提供了缓存等好处。

最后的想法

如果你已经看到了这里,那么恭喜你!这篇文章的目的就是为那些学习 React 的人介绍一些不同的数据获取方法。

在这篇文章中,我介绍了6种方法,希望这6种方法对你有用,也希望你能从中学习到一些新东西。

此外,还有其他当前的数据获取方法未在此文章中提及,我相信随着 React 生态系统的发展,其他方法将会出现。也就是说,我相信本文为理解该领域提供了坚实的基础。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【宝藏系列】嵌入式 C 语言代码优化技巧【超详细版】

【宝藏系列】嵌入式 C 语言代码优化技巧【超详细版】 文章目录 【宝藏系列】嵌入式 C 语言代码优化技巧【超详细版】前言整形数除法和取余数合并除法和取余数通过2的幂次进行除法和取余数取模的一种替代方法使用数组下标全局变量使用别名变量的生命周期分割变量类型局部变量指针…

开源,微信小程序 美食便签地图(FoodNoteMap)的设计与开发

目录 0 前言 1 美食便签地图简介 2 美食便签地图小程序端开发 2.1技术选型 2.2前端UI设计 2.3主页界面 2.4个人信息界面 2.5 添加美食界面 2.6美食便签界面 2.8 美食好友界面 2.9 美食圈子界面 2.10 子页面-店铺详情界面 2.11 后台数据缓存 2.12 订阅消息通知 2.1…

UI自动化测试常见的Exception

一. StaleElementReferenceException&#xff1a; - 原因&#xff1a;引用的元素已过期。原因是页面刷新了&#xff0c;此时当然找不到之前页面的元素。- 解决方案&#xff1a;不确定什么时候元素就会被刷新。页面刷新后重新获取元素的思路不变&#xff0c;这时可以使用python的…

【GitLab私有仓库】如何在Linux上用Gitlab搭建自己的私有库并配置cpolar内网穿透?

文章目录 前言1. 下载Gitlab2. 安装Gitlab3. 启动Gitlab4. 安装cpolar5. 创建隧道配置访问地址6. 固定GitLab访问地址6.1 保留二级子域名6.2 配置二级子域名 7. 测试访问二级子域名 前言 GitLab 是一个用于仓库管理系统的开源项目&#xff0c;使用Git作为代码管理工具&#xf…

【Nginx17】Nginx学习:目录索引、字符集与浏览器判断模块

Nginx学习&#xff1a;目录索引、字符集与浏览器判断模块 今天要学习的内容有几个还是大家比较常见的&#xff0c;所以学习起来也不会特别费劲。对于目录的默认页设置大家都不会陌生&#xff0c;字符集的设置也比较常见&#xff0c;而浏览器的判断这一块&#xff0c;可能有同学…

XenDesktop5.6如何连接数据库

Citrix在数据库的连接方式上一直不统一&#xff0c;但是也还是有迹可循的。 经过了好长时间的下载以后&#xff0c;今天终于有时间来测试一下最新版本的XenDesktop 5 SP1&#xff0c;由于结合了其他组件和环境的需要&#xff0c;所以&#xff0c;选择了独立部署数据库&#xf…

【学习笔记之opcua】使用Python获取opcua数据

Python与OPC UA的应用 示例代码 将代码放入spyder中运行后&#xff0c;出现下面这个错误 没有‘opcua’&#xff0c;那我们就下载pip install opcua 之后出现下面这个错误 问问题大不&#xff0c;安装语句写错了 正经安装语句是 !pip install opcua 读取opcua协议数据测试 …

若依框架给字典字段新增color值,并且实现下拉列表选项进行颜色设置

首先获取所要新增的字典&#xff0c;并且根据字典的value值选取对应的颜色参数 this.getDicts("risk_level").then(response > {const color {mild:#F1F4BD,moderate:#EEC920,severe:#FF6C0D,very_severe:#FF0000,no_harm:green};const res response.data.map(…

深兰科技熊猫汽车牵手首恒出行,人工智能技术提升商用车运营服务

8月8日&#xff0c;深兰科技集团旗下熊猫新能源汽车(上海)有限公司(下称熊猫新能源汽车)与河南首恒出行服务有限公司(下称首恒出行)在深兰科技总部举行签约仪式&#xff0c;首恒出行将向熊猫新能源汽车年定向采购10000台商用车&#xff0c;双方将在汽车后市场领域进行技术合作。…

如何在出差期间远程访问企业ERP系统?内网穿透解决您的难题!

文章目录 概述1.查看象过河服务端端口2.内网穿透3. 异地公网连接4. 固定公网地址4.1 保留一个固定TCP地址4.2 配置固定TCP地址 5. 使用固定地址连接 概述 ERP系统对于企业来说重要性不言而喻&#xff0c;不管是财务、生产、销售还是采购&#xff0c;都需要用到ERP系统来协助。…

动画制作选择Blender还是Maya

Blender和Maya是两种最广泛使用的 3D 建模和动画应用程序。许多经验丰富的用户表示&#xff0c;Blender 在雕刻工具方面远远领先于 Maya&#xff0c;并且在 3D 建模方面达到了相同的质量水平。对于刚接触动画行业的人来说&#xff0c;您可能会问“我应该使用 Blender 还是 Maya…

【操作系统】24王道考研笔记——第一章 计算机系统概述

第一章 计算机系统概述 一、操作系统基本概念 1.1 定义 1.2 特征 并发 &#xff08;并行&#xff1a;指两个或多个事件在同一时刻同时发生&#xff09; 共享 &#xff08;并发性指计算机系统中同时存在中多个运行着的程序&#xff0c;共享性指系统中的资源可供内存中多个并…

网络连接(3次握手和4次挥手)

在进行3次握手和4次挥手传输数据时&#xff0c;都可能会出现丢包的情况&#xff0c;推荐看出现丢包问题的情况以及解决方法 一.为什么要进行3次握手&#xff1f; 在进行网络连接时&#xff0c;需要3次握手 3次握手的初心就是两方面&#xff1a; 1.投石问路&#xff0c;验证通…

HDMI接口的PCB布局布线要求

高清多媒体接口&#xff08;High Definition Multimedia Interface&#xff09;&#xff0c;简称&#xff1a;HDMI&#xff0c;是一种全数字化视频和声音发送接口&#xff0c;可以发送未压缩的音频及视频信号。随着技术的不断提升&#xff0c;HDMI的传输速率也不断的提升&#…

【力扣每日一题】1572. 矩阵对角线元素的和 8.11打卡

文章目录 题目思路代码 题目 1572. 矩阵对角线元素的和 难度&#xff1a; 简单 描述&#xff1a; 给你一个正方形矩阵 mat&#xff0c;请你返回矩阵对角线元素的和。 请你返回在矩阵主对角线上的元素和副对角线上且不在主对角线上元素的和。 返回合并后的二叉树。 注意…

企业权限管理(十)-用户详情

用户详情 UserController findById方法 Controller RequestMapping("/user") public class UserController {Autowiredprivate IUserService userService;//查询指定id的用户RequestMapping("/findById.do")public ModelAndView findById(String id) thro…

【设计模式——学习笔记】23种设计模式——状态模式State(原理讲解+应用场景介绍+案例介绍+Java代码实现)

文章目录 案例引入介绍基本介绍登场角色应用场景 案例实现案例一类图实现 案例二&#xff1a;借贷平台源码剖析传统方式实现分析状态修改流程类图实现 案例三&#xff1a;金库警报系统系统的运行逻辑伪代码传统实现方式使用状态模式 类图实现分析问题问题一问题二 总结文章说明…

【广州华锐视点】VR线上教学资源平台提供定制化虚拟现实学习内容

虚拟现实&#xff08;VR&#xff09;技术的出现为我们提供了一种全新的在线教学方式。由广州华锐视点开发的VR线上教学资源平台&#xff0c;作为一个综合性的学习工具&#xff0c;正在教育领域迅速发展&#xff0c;并被越来越多的教育机构和学生所接受。那么&#xff0c;VR线上…

TikTok广告投放如何做?2023超全实用干货

目前Tiktok月活用户达到12亿&#xff0c;覆盖150地方&#xff0c;66%用户年龄30以下&#xff0c;流量不容小觑。在部分地区&#xff0c;TikTik广告已经是能够与Facebook与Google广告掰掰手腕的程度了。且目前来说&#xff0c;投放TikTok ads的成本比FB ads要低一些&#xff0c;…

搭建Web服务器并用cpolar发布至公网访问

本地电脑搭建Web服务器并用cpolar发布至公网访问 文章目录 本地电脑搭建Web服务器并用cpolar发布至公网访问前言1. 首先在电脑安装PHPStudy、WordPress、cpolar2. 安装cpolar&#xff0c;进入Web-UI界面3. 安装wordpress4. 进入wordpress网页安装程序5. 利用cpolar建立的内网穿…