中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React 中怎么請求遠程數據

發布時間:2021-08-11 16:08:16 來源:億速云 閱讀:129 作者:Leah 欄目:web開發

本篇文章給大家分享的是有關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 中怎么請求遠程數據,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

金湖县| 沙河市| 安图县| 古丈县| 衡阳市| 平度市| 和平区| 藁城市| 黄陵县| 黔江区| 馆陶县| 大足县| 循化| 丹东市| 合水县| 库伦旗| 龙山县| 大足县| 珠海市| 崇仁县| 镇平县| 海安县| 云和县| 嫩江县| 奉贤区| 鲜城| 阿图什市| 酉阳| 曲水县| 紫金县| 桓台县| 特克斯县| 中方县| 文安县| 岑溪市| 柳河县| 同仁县| 奉贤区| 南岸区| 灵台县| 乾安县|