我的编程空间,编程开发者的网络收藏夹
学习永远不晚

React 中怎么请求远程数据

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

React 中怎么请求远程数据

本篇文章给大家分享的是有关React 中怎么请求远程数据,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

方式1:内联

这是最简单,最直接的选择。在 React 组件中进行 HTTP 调用并处理响应。

fetch("/users").then(response => response.json());

看起来很简单。但是这个示例忽略了加载状态,错误处理,声明和设置相关状态等。在现实世界中, HTTP 调用看起来更像这样。

import React, { useState, useEffect } from "react";  export default function InlineDemo() {   const [users, setUsers] = useState([]);   const [loading, setLoading] = useState(true);   const [error, setError] = useState(null);    useEffect(() => {     fetch(`${process.env.REACT_APP_API_BASE_URL}users`)       .then(response => {         if (response.ok) return response.json();         throw response;       })       .then(json => {         setUsers(json);       })       .catch(err => {         console.error(err);         setError(err);       })       .finally(() => {         setLoading(false);       });   }, []);    if (loading) return "Loading...";   if (error) return "Oops!";   return users[0].username; }

对于一个简单的应用程序,只要发起几个请求,就可以正常工作。但是上面的状态声明和 useEffect 都是模版。如果我要进行许多 HTTP  调用,我不想为每个调用重复和维护大约 20 行代码。内联调用让你的代码变得很丑。

看一下我们要解决的一些问题:

  • 声明加载状态

  • 声明错误状态

  • 将错误打印到控制台

  • 检查响应是否通过返回 200 response.ok

  • 如果响应正常,将响应转换为 json 并返回 promise

  • 如果响应不正确,抛出错误

  • 在 finally 中隐藏加载状态,以确保 Loading 即使发生错误也被隐藏

  • 声明一个空的依赖项数组,以便 useEffect 只运行一次

这只是一个简单的示例,它忽略了许多其他相关问题。

方式2:文件夹集中管理

如果我们在一个文件夹中处理所有 HTTP 调用会怎么样? 使用这种方法,我们创建了一个名为 services 的文件夹,并且把进行  HTTP 调用的函数都放进去。service 是比较流行的术语,我在下面也讨论了很多好的替代名称,如 client 或 api。

React 中怎么请求远程数据

要点是,所有的 HTTP 调用都是通过纯 JavaScript 函数处理的,存储在一个文件夹中。这是一个集中的 getUsers 函数:

export function getUsers() {   return fetch(`${process.env.REACT_APP_API_BASE_URL}users`).then(response =>     response.json()   ); }

下面是对 getUsers 函数的调用:

import React, { useState, useEffect } from "react"; import { getUsers } from "./services/userService";  export default function CentralDemo() {   const [users, setUsers] = useState([]);   const [loading, setLoading] = useState(true);   const [error, setError] = useState(null);   useEffect(() => {     getUsers()       .then(json => {         setUsers(json);         setLoading(false);       })       .catch(err => {         console.error(err);         setError(err);       });   }, []);    if (loading) return "Loading...";   if (error) return "Oops!";   return users[0].username; }

然而这并没有太简化请求调用。主要的好处是它可以强制一致地处理 HTTP 调用。其思想是这样的:当相关函数一起处理时,更容易一致地处理它们。如果  userService 文件夹中充满了进行 HTTP  调用的函数,那么我可以很容易地确保它们始终如一地这样做。此外,如果调用被复用,则很容易从这个集中位置调用它们。

然而,我们还可以做得更好。

方式3:自定义Hook

借助 React Hooks 的魔力,我们终于可以集中处理重复的逻辑。那么如何创建一个自定义 useFetch 钩子来简化我们的  HTTP 调用呢?

import { useState, useEffect, useRef } from "react"; // This custom hook centralizes and streamlines handling of HTTP calls export default function useFetch(url, init) {   const [data, setData] = useState(null);   const [loading, setLoading] = useState(true);   const [error, setError] = useState(null);   const prevInit = useRef();   const prevUrl = useRef();    useEffect(() => {   // Only refetch if url or init params change.     if (prevUrl.current === url && prevInit.current === init) return;     prevUrl.current = url;     prevInit.current = init;     fetch(process.env.REACT_APP_API_BASE_URL + url, init)       .then(response => {         if (response.ok) return response.json();         setError(response);       })       .then(data => setData(data))       .catch(err => {         console.error(err);         setError(err);       })       .finally(() => setLoading(false));   }, [init, url]);    return { data, loading, error }; }

你的可能看起来不一样,但我发现这个基本的使用方法很有用。这个 Hook 极大地简化了所有调用。看看使用这个 Hook 需要多少代码 :

import React from "react"; import useFetch from "./useFetch";  export default function HookDemo() {   const { data, loading, error } = useFetch("users");   if (loading) return "Loading...";   if (error) return "Oops!";   return data[0].username; }

对于许多应用程序,你只需要一个这样的自定义Hook。但是这个Hook已经很复杂了,并且它消除了许多问题。

但是还有很多我们没有考虑到的点:缓存?、如果客户端的连接不可靠,如何重新获取?你想在用户重新调整标签时重新获取新数据吗?如何消除重复查询?

你可以不断完善这个自定义Hook来完成所有这些操作。但是,您应该只需要方式4:

方式4:react-query/swr

使用  react-query或swr,可以为我们处理缓存、重试、重复查询等等。我不必维护自己的自定义Hook了。而且每个 HTTP 调用都需要很少的代码:

import React from "react"; import { getUsers } from "./services/userService"; import { useQuery } from "react-query";  export default function ReactQueryDemo() {   const { data, isLoading, error } = useQuery("users", getUsers);   if (isLoading) return "Loading...";   if (error) return "Oops!";   return data[0].username; }

以上就是React 中怎么请求远程数据,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

React 中怎么请求远程数据

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

react fetch怎么请求数据

react fetch请求数据的方法:1、将请求的方法放在生命周期的“componentDidMount”里;2、封装fetch请求;3、通过“function checkStatus(response){...}”方法检查请求状态;4、使用封装好的请求并在服务端或浏览器打印结果即可。
2023-05-14

react怎么请求数据异步

react请求数据异步的方法:1、通过“npm i redux-thunk --save npm i axios --save”命令下载thunk;2、在store.js里面引入thunk插件;3、在需要模块的actionCreator里引入中间件“redux-thunk”即可。
2023-05-14

react后端请求数据怎么实现

react后端请求数据的实现方法:1、在package.json中配置“ "proxy":"http://localhost:5000"”;2、在src目录下创建“setupProxy.js”文件;3、调用“setupProxy.js”中配置的功能,代码如“createProxyMiddleware('/api2',{target:...}”。
2023-05-14

react异步请求数据怎么实现

在React中实现异步请求数据有多种方式,以下是其中几种常用的方法:1. 使用`fetch` API:`fetch`是现代浏览器提供的一种网络请求API,可以用于发送HTTP请求并获取响应数据。可以在React组件的生命周期方法(如`com
2023-09-13

react异步请求数据的方法是什么

在React中,常用的异步请求数据的方法有以下几种:1. 使用fetch API:fetch是现代浏览器提供的一种用于进行网络请求的方法,它返回一个Promise对象,可以使用.then()方法来处理请求的结果。```javascriptf
2023-08-19

React之如何在Suspense中优雅地请求数据

Suspense是React中的一个组件,直译过来有悬挂的意思,能够将其包裹的异步组件挂起,直到组件加载完成后再渲染,本文详细介绍了如何在Suspense中请求数据,感兴趣的小伙伴可以参考阅读本文
2023-05-17

react请求数据并渲染的方法是什么

在React中,可以使用fetch或axios等库来发送请求并获取数据。一般情况下,在组件的生命周期方法中发送请求并在获取到数据后进行渲染。以下是一个使用fetch发送请求并渲染数据的例子:```jsximport React, { use
2023-10-07

Java中SpringMVC怎么获取请求数据

本文小编为大家详细介绍“Java中SpringMVC怎么获取请求数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java中SpringMVC怎么获取请求数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.获
2023-06-29

JAVA中怎么使用多线程并行请求数据

在Java中使用多线程并行请求数据可以使用线程池来实现。以下是一个简单的示例代码:```javaimport java.util.concurrent.ExecutorService;import java.util.concurrent.
2023-08-14

SpringMVC怎么映射请求数据

这篇文章主要介绍了SpringMVC怎么映射请求数据的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringMVC怎么映射请求数据文章都会有所收获,下面我们一起来看看吧。1.获取参数值1.说明开发中,如何获取
2023-07-02

Vuejs怎么通过Axios请求数据

本文小编为大家详细介绍“Vuejs怎么通过Axios请求数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vuejs怎么通过Axios请求数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。通过Axios请求数据
2023-06-29

springboot怎么获取请求体数据

在Spring Boot中,您可以使用@RequestBody注解将请求体数据绑定到方法参数上。以下是一些示例:将请求体数据绑定到一个对象上:@PostMapping("/example")public ResponseEntity ex
2023-10-26

Node.js中怎么处理POST请求并获取请求参数

本篇内容介绍了“Node.js中怎么处理POST请求并获取请求参数”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!接收POST请求在Node.
2023-07-05

java怎么防止重复请求数据

有以下几种方法可以防止重复请求数据:前端防重复提交:前端可以通过禁用提交按钮或者添加遮罩层等方式,在接收到请求后禁止用户再次提交,待请求返回后再恢复提交按钮的状态。后端去重:后端可以在接收到请求时,根据请求的特征(如请求参数、请求路径等)判
2023-10-25

vue中数据请求axios怎么封装和使用

这篇文章主要介绍了vue中数据请求axios怎么封装和使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue中数据请求axios怎么封装和使用文章都会有所收获,下面我们一起来看看吧。一、什么是axios
2023-06-30

编程热搜

目录