公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

React 入門基礎:AJAX

admin
2024年12月7日 0:15 本文熱度 907

?? 如果還不了解 HTML 、 CSS和JS,可以參考本號下的 HTML21 天入門教程、 CSS 21 天入門教程和JS21天入門教程

在 React 應用中實現 AJAX 請求,有以下兩種方式:

  1. 使用 window.fetch API。
  2. 使用第三方庫如 axios、JQuery 等。

無論使用哪一種,基本上實現的都是副作用,而前面說過,副作用使用 useEffect 鉤子來處理。

一個例子

假設現在有一個獲取 Course 的 API,它返回的數據如下:

{  "courses": [    { "id": 1, "name": "HTML入門",  "description": "基礎課程。" },    { "id": 2, "name": "CSS入門", "description": "基礎課程。" },    { "id": 3, "name": "JavaScript入門", "description": "基礎課程。" },  ] } 

現在需要調用此 API 獲取提供的數據,并顯示在頁面上。

CourseComponent 組件實現這個功能。

function CourseComponent() {  const [error, setError] = useState(null);  const [isLoaded, setIsLoaded] = useState(false);  const [courses, setCourses] = useState([]);   useEffect(() => {    fetch("https://api.xxx.com/courses") //返回上述JSON格式的數據。      .then(res => res.json())      .then(        (result) => {          setIsLoaded(true);          setCourses(result);        },        (error) => {          setIsLoaded(true);          setError(error);        }      )  }, [])   if (error) {    return <div>Error: {error.message}</div>;  } else if (!isLoaded) {    return <div>Loading...</div>;  } else {    return (      <div>        <ul>          {courses.map(course => (            <li key={course.id}>              {course.name}: {course.description}            </li>          ))}        </ul>      </div>    );  } } 

上述代碼中的 useEffect 中,通過 fetch 方法調用 courses 的 API。

這里同時加上錯誤處理,這是好的習慣。

在 return 里,通過 map 方法遍歷 courses 的值,并通過列表呈現出來。

使用 axios 庫

以上代碼可以使用 axios 庫來實現。

因為 axios 是第三方庫,使用前需要安裝它。

使用 npm 通過命令 npm install axios 安裝。

然后,在組件代碼中引入它。

import axios from 'axios';  function CourseComponent() {  const [error, setError] = useState(null);  const [isLoaded, setIsLoaded] = useState(false);  const [courses, setCourses] = useState([]);   useEffect(() => {    axios.get("https://api.xxx.com/courses") //返回上述JSON格式的數據。      .then(res => res.json())      .then(        (result) => {          setIsLoaded(true);          setCourses(result);        },        (error) => {          setIsLoaded(true);          setError(error);        }      )  }, [])   if (error) {    return <div>Error: {error.message}</div>;  } else if (!isLoaded) {    return <div>Loading...</div>;  } else {    return (      <div>        <ul>          {courses.map(course => (            <li key={course.id}>              {course.name}: {course.description}            </li>          ))}        </ul>      </div>    );  } } 

以上這種在 Effect 中直接寫 fetch 請求是一種常見的數據獲取方式。

但是這種方法有很多需要手動處理的部分,且有明顯的弊端。

因此對于正式的項目,React 官方首推使用基于 React 的框架,比如說 next.js,這種框架里內置有數據獲取方式。

它會解決直接寫 fetch 帶來的比如,效率低,不夠簡潔之類的弊端。

總結

最后來總結一下今天的內容要點:

  • ?? 在 React 中實現 AJAX 請求可以通過 fetch API 或第三方庫。
  • ?? 在 useEffect 鉤子中處理 AJAX 這樣的副作用。
  • ?? 在正式的項目中,不推薦自己處理數據請求 fetch,而是推薦使用框架內置的數據獲取方式。

該文章在 2024/12/9 18:40:16 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产精品福利在线观看 | 国产凹凸在线观看一区二区 | 国产精品麻豆羞羞答答 | 高清久久久久久久久 | 精品国产va久久久久久久冰 | 爆乳无码av一区二区三区 | h无码精品 | av激情亚洲男人的天堂国语 | 国产精品午夜性色视频 | av无码中文字幕 | 国产高潮丝袜熟女视频 | 国产一区二区三区精品久久 | a级国产欧美激情在线 | 成人午夜精品久久久久久久网 | 91精品国内久久久久精品一本 | 国产二区视频在线观看 | 91视频精品安全吗 | 国产在线一区二区三区旡码 | 国产中文亚洲熟女日韩 | 97色伦在色在线视频 | 国产无码电影一区二区三区 | 国产91白浆四溢 | 国产成人a视频高清视频在线 | 国产爆乳无码视频在线观看3 | 国产产无码乱码精品久久鸭 | 东京热亚洲中文一区 | 国产超级乱淫视频播放免费 | 国产一区二区日韩欧美在线 | 国产成人无码精品一区 | 国产精品高清一区二区三区久久 | 国产福利短片视频在线观看 | 18禁成年免费无码国产 | 91精品国产91久 | 国产亚洲成aⅴ人片在线观看嫩草 | 国产韩国欧美在线 | 国产精品乱子伦一区二区三区 | 国产日韩欧美一区二区综合区 | 国产经典自拍一区 | 91久久精品无码一区二区毛片 | 99久久这里只有免费精品 | 韩国女主播福利一区二区三区 |