狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

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

你知道 XHR 和 Fetch 的區別嗎?

freeflydom
2023年11月27日 11:38 本文熱度 595

現如今,網站開發普遍采用前后端分離的模式,數據交互成為了不可或缺的關鍵環節。在這個過程中,XHRFetch API 是兩種最常見的方法,用于從 Web 服務器獲取數據。XHR 是一種傳統的數據請求方式,而 Fetch API 則代表了現代 Web 開發的新興標準。接下來,我們將一同深入學習它們的使用方法和適用場景。

XMLHttpRequest

XMLHttpRequest,通常簡稱為 XHR。通過 XMLHttpRequest 可以在不刷新頁面的情況下請求特定 URL,獲取數據。XMLHttpRequest 在 AJAX 編程中(比如 jquery)被大量使用。

AJAX :異步 Javascript 和 XML。許多人容易把它和 jq 的 ajax 混淆。它是一個技術統稱,本身不是一種技術。

特點

  1. 異步請求:XHR 允許進行異步請求,它可以在后臺執行,而不會阻止頁面的其他操作。

  2. 支持跨域請求:通過服務器端設置允許跨域請求,從不同域的服務器獲取數據。

  3. 事件驅動:提供了 onload、onerroronprogress 等一系列事件來監聽請求的狀態變化。

  4. 靈活性:提供了對請求頭、響應頭以及請求方法的完全控制,使其非常靈活。

工作原理

XHR 的工作原理主要為:

  1. 創建 XHR 對象實例:通過new XMLHttpRequest()創建一個 XHR 對象。

  2. 配置請求:使用open()方法設置請求方法(GET、POST 等)、URL,以及是否要異步執行請求。

  3. 設置回調函數:設置事件處理程序來處理請求完成、成功、失敗等不同的狀態。

  4. 發起請求:使用send()方法發送請求。

  5. 處理響應:在事件處理程序中處理響應數據,通常使用responseTextresponseXML來訪問響應內容。

// 創建一個新的XHR對象

const xhr = new XMLHttpRequest();


// 配置請求

xhr.open("GET", "https://api.baidu.com/test", true);


// 設置響應處理函數

xhr.onload = function() {

  if (xhr.status === 200) {

    // 請求成功

    const responseData = xhr.responseText;

    console.log("成功獲取數據:", responseData);

  } else {

    // 請求失敗

    console.error("請求失敗,狀態碼:" + xhr.status);

  }

};


// 發起請求

xhr.send();


XHR 的響應處理通常在onreadystatechange事件處理程序中完成。在上面的例子中,我們等待 XHR 對象的狀態變為 4(表示請求完成)并且 HTTP 狀態碼為 200(表示成功響應)時,解析響應數據。

Fetch API

Fetch 是一種現代的數據網絡請求 API,它旨在解決 XHR 的一些問題,提供了更強大、更靈活的方式來處理 HTTP 請求。可以理解為 XMLHttpRequest 的升級版。

特點

  1. Promise 風格:Fetch API 使用 Promise 對象來處理異步請求,使代碼更具可讀性和可維護性。

  2. 更簡單的語法:相較于 XHR,Fetch API 的語法更加簡單明了,通常只需要幾行代碼來完成請求。

  3. 默認不接受跨域請求:為了安全性,Fetch API 默認不接受跨域請求,但可以通過 CORS(跨域資源共享)來進行配置。

  4. 更現代的架構:Fetch API 是建立在 PromiseStream 之上的,支持更靈活的數據處理和流式傳輸。

工作原理

Fetch 的工作原理主要為:

  1. 使用fetch()函數創建請求:傳入要請求的 URL,以及可選的配置參數,例如請求方法、請求頭等。

  2. 處理響應:fetch()返回一個 Promise,您可以使用.then()鏈式調用來處理響應數據,例如使用.json()方法解析 JSON 數據或.text()方法獲取文本數據。

  3. 錯誤處理:您可以使用.catch()方法來捕獲任何請求或響應的錯誤。

  4. 使用async/await:如果需要,您還可以使用async/await來更清晰地處理異步操作。

Fetch API 的特性和簡單的語法使它在許多前端項目中成為首選工具。然而,它也有一些限制,例如不支持同步請求,因此需要謹慎使用。

fetch("https://api.baidu.com/test")

  .then(response => {

    if (!response.ok) {

      throw new Error("請求失敗,狀態碼:" + response.status);

    }

    return response.json();

  })

  .then(data => {

    // 請求成功,處理響應數據

    console.log("成功獲取數據:", data);

  })

  .catch(error => {

    // 請求失敗,處理錯誤

    console.error(error);

  });


XHR 和 Fetch 的對比

XHR 和 Fetch 都用于進行 HTTP 請求,但它們之間存在一些關鍵區別:

  • 語法: Fetch 使用 Promise,更直觀和易于理解。

  • 跨域請求: Fetch 在跨域請求方面更靈活,支持 CORS。

  • 流式傳輸: Fetch 支持可讀流,適用于大文件下載。

  • 維護性: Fetch 更容易維護和擴展。

常用庫和插件

基于 XHR 封裝的庫

  • jquery:一個 Javascript 庫,提供了用于處理 DOM 操作、事件處理和 XHR 請求的便捷方法。

  • axios:一個流行的 HTTP 請求庫,基于 XHR 開發,支持瀏覽器和 Node.js。

基于 fetch 封裝的庫

  • redaxios:它具有與 axios 類似的 API,但更輕量級且適用于現代 Web 開發。

  • umi-request:由 Umi 框架維護的網絡請求庫,提供了強大的攔截器、中間件和數據轉換功能。

總結

XMLHttpRequest (XHR) 和 Fetch API 都是前端開發中用于進行數據請求的有力工具。XHR 在傳統項目中仍然有用,而 Fetch API 則在現代 Web 開發中越來越流行。具體選擇哪個工具取決于項目的需求和開發團隊的偏好,希望本文對你有幫助!


作者:王絕境
鏈接:https://juejin.cn/post/7295551704816189467
來源:稀土掘金
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。



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