日韩欧美人妻无码精品白浆,www.大香蕉久久网,狠狠的日狠狠的操,日本好好热在线观看

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

React 入門基礎(chǔ):AJAX

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

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

在 React 應(yīng)用中實(shí)現(xiàn) AJAX 請(qǐng)求,有以下兩種方式:

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

無(wú)論使用哪一種,基本上實(shí)現(xiàn)的都是副作用,而前面說(shuō)過(guò),副作用使用 useEffect 鉤子來(lái)處理。

一個(gè)例子

假設(shè)現(xiàn)在有一個(gè)獲取 Course 的 API,它返回的數(shù)據(jù)如下:

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

現(xiàn)在需要調(diào)用此 API 獲取提供的數(shù)據(jù),并顯示在頁(yè)面上。

CourseComponent 組件實(shí)現(xiàn)這個(gè)功能。

function CourseComponent() {  const [error, setError] = useState(null);  const [isLoaded, setIsLoaded] = useState(false);  const [courses, setCourses] = useState([]);   useEffect(() => {    fetch("https://api.xxx.com/courses") //返回上述JSON格式的數(shù)據(jù)。      .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 中,通過(guò) fetch 方法調(diào)用 courses 的 API。

這里同時(shí)加上錯(cuò)誤處理,這是好的習(xí)慣。

在 return 里,通過(guò) map 方法遍歷 courses 的值,并通過(guò)列表呈現(xiàn)出來(lái)。

使用 axios 庫(kù)

以上代碼可以使用 axios 庫(kù)來(lái)實(shí)現(xiàn)。

因?yàn)?axios 是第三方庫(kù),使用前需要安裝它。

使用 npm 通過(guò)命令 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格式的數(shù)據(jù)。      .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 請(qǐng)求是一種常見(jiàn)的數(shù)據(jù)獲取方式。

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

因此對(duì)于正式的項(xiàng)目,React 官方首推使用基于 React 的框架,比如說(shuō) next.js,這種框架里內(nèi)置有數(shù)據(jù)獲取方式。

它會(huì)解決直接寫 fetch 帶來(lái)的比如,效率低,不夠簡(jiǎn)潔之類的弊端。

總結(jié)

最后來(lái)總結(jié)一下今天的內(nèi)容要點(diǎn):

  • ?? 在 React 中實(shí)現(xiàn) AJAX 請(qǐng)求可以通過(guò) fetch API 或第三方庫(kù)。
  • ?? 在 useEffect 鉤子中處理 AJAX 這樣的副作用。
  • ?? 在正式的項(xiàng)目中,不推薦自己處理數(shù)據(jù)請(qǐng)求 fetch,而是推薦使用框架內(nèi)置的數(shù)據(jù)獲取方式。

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

大香蕉看片地址| 色综合凹凸| 欧美 日韩 久久 精品一区| 在线丁香婷婷| 国内夫妻性生活视频网站| 亚洲综合图区一区二区三区| 国产一区国产二区国产三区,| 中文字幕无码高清在线视频| 黄色大片久久久| 自拍 偷拍 日韩 国产 传媒| 殴美午夜福利一区二区| 青娱乐极品盛宴一区二区三区| 中文字幕精品久久久久久久影院| 黄色三级片国厂| 99的国产精品白浆| 2019欧美一级黄片| 日本成人在线91| 欧洲在线观看成人免费| 久久韩国经典国产| 国内日韩欧美在线观看免费| 亚洲伦理久久久久久久久| 亚洲午夜精品福利电影| 一区二区三区不卡日本亚洲欧美| 欧美多人运动操逼| 伊人十月激情综合| 精品综合久久少妇| 天天日天天干天天天天射| 欧美激情欧美少妇| 午夜影院免费区| 欧美亚洲日韩欧美日韩| 日韩成人性网址| 99久久国产精| 人妻一级二级三| 无碼视频一区| 国产成人精欧美视频虐| 18禁一区大全彩| 操熟女肥穴| 91在线国啪| 妞干网欧美视频免费| 大香蕉猫咪伊人综合| 操妇人骚逼操逼|