精品秘无码一区二区三区老师-精品秘一区二三区免费雷安-精品蜜桃秘一区二区三区-精品蜜桃秘一区二区三区粉嫩-精品蜜桃一区二区三区-精品蜜臀国产aⅴ一区二区三区

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

【JavaScript】了解為什么Fetch有時候需要兩次 await

admin
2024年12月28日 23:21 本文熱度 222

在 JavaScript 中,fetch API 是一種常見的 HTTP 請求工具,但其需要兩次 await 的機制可能讓初學者感到疑惑。本文將通過示例與解析,理解這一特性。


基礎示例

const response = await fetch('https://api.example.com/data');
const data = await response.json();

上面的代碼為什么需要兩次 await

Fetch 的兩階段流程

1. 獲取響應

調用 fetch 時,它返回一個 Promise,在網絡請求完成后解析為 Response 對象:

  • 僅獲取元數據:此時只獲取響應頭信息,正文尚未處理。

2. 解析響應正文 ??

Response 對象包含的方法(如 .json().text())用于讀取正文,這些方法返回另一個 Promise,因為讀取和解析正文是異步操作。


第一次 await 的內部流程

當你執行以下代碼:

const response = await fetch(url);

1. 發送請求

瀏覽器向指定 URL 發起網絡請求:

  • 解析域名
  • 建立 TCP 連接
  • 發送 HTTP 請求

2. 接收響應元數據

  • 服務器返回狀態行(如 HTTP/1.1 200 OK)和響應頭后,fetch 的 Promise 解析。
  • 此時,你可以獲取:
    • 狀態碼:如 200404
    • 狀態文本:如 "OK""Not Found"
    • 響應頭:如 Content-Type: application/json

3. 構造 Response 對象

  • 包含元數據的 Response 對象被創建:
    • Headers:通過 response.headers 獲取。
    • Body:正文仍是未處理的可讀流。

第二次 await 的內部流程

當你執行以下代碼:

const data = await response.json();

1. 讀取正文流

Response 對象的正文被解析為流:

  • .json():解析為 JSON 并返回 JavaScript 對象。
  • .text():讀取為純文本字符串。
  • .blob():讀取為二進制大對象。

2. 異步解析

  • 流數據被解析為可用內容(如 { message: "Hello, world!" })。
  • 解析過程可能處理大數據,因此是異步的。

3. 返回解析結果

  • response.json() 返回的 Promise 解析為解析后的數據,可用于程序邏輯。

為什么需要兩次 await

兩次 await 是 Fetch 的設計邏輯,分別解決以下問題:

  1. **第一次 await**:

    • 等待網絡請求完成,獲取 Response 對象(包含狀態碼、頭信息等元數據)。
  2. **第二次 await**:

    • 異步讀取和解析響應正文,確保數據可用。

如果跳過任意一次 await 會如何?

  • **跳過第一次 await**:
    • 你將得到一個未解析的 Promise,而非 Response 對象。
  • **跳過第二次 await**:
    • 你將得到未解析的 Promise,而非解析后的數據。

完整示例:帶錯誤處理

以下是一個完整的示例,展示如何正確處理錯誤:

try {
  const response = await fetch('https://api.example.com/data');
  
  if (!response.ok) {
    throw new Error(`HTTP error! Status: ${response.status}`);
  }
  
  const data = await response.json();
  console.log(data);
catch (error) {
  console.error('Error fetching data:', error);
}

錯誤處理注意點:

  1. **檢查 response.ok**:fetch 不會對 HTTP 錯誤(如 404 或 500)拋出異常。
  2. 捕獲解析錯誤:如果響應正文不符合預期格式(如 JSON 格式錯誤),解析時也會拋出異常。

常見問題與解決方案

1. 忘記錯誤處理

  • 問題fetch 默認不會對 HTTP 錯誤拋出異常,可能導致你誤以為請求成功。
  • 解決:手動檢查 response.ok 或 response.status

2. 忘記第二次 await

  • 問題:會導致代碼處理未解析的 Promise,而非實際數據。
  • 解決:始終 await 解析方法(如 .json())。

3. 舊 API 的影響

  • 問題:從 XMLHttpRequest 等同步 API 遷移的開發者可能預期同步行為。
  • 解決:理解并適應 fetch 的 Promise 異步設計。

總結

使用 Fetch API 時,兩次 await 是其異步設計的結果:

  1. **第一次 await**:確保接收到響應元數據。
  2. **第二次 await**:解析響應正文,獲取最終數據。

理解 Fetch 的工作機制能幫助你編寫更高效、可靠的異步代碼!

?

閱讀原文:原文鏈接


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

主站蜘蛛池模板: 在线观看精品国产福利片100 | 亚洲国产成人最新精品麻豆 | 午夜宅宅伦电影网 | 久久久久国产成人精品亚洲午夜 | 无码专区人妻丝袜久久 | 国产精品福利影院 | 国产乱子经典视频在线观看 | 毛片tv网站无套内射tv网站 | 免费无码av一区二区 | 日本一本免费一二区 | 久久亚洲精品成人无码网站夜色 | 孕妇性孕交xxxx | 亚洲一道av无码午夜福利 | 亚洲一二三在线 | 日韩欧美精品有码在线 | 无套内射在线无码播放 | 国产成人无码视频一区二区三区 | 精品一区二区久久久久久久网站 | 色综合99久久久无码国产精 | 成人无码一区二区三区网站 | 插B内射18免费视频 插吧插吧综合网 | 自拍亚洲日韩一区 | 国产人妻人伦又粗又大爽歪歪 | 国产露脸无码A区久久蘑菇 国产乱xxⅹxx国语对白 | 麻豆精品国产91久久久久久黄无码亚洲精品无码国产成人 | 国产精品久久久久无毒 | 日韩一区精品视频一区二区 | 亚洲一区二区三区福利在线 | 女人和拘做受全程看视频 | 午夜福利无码不卡在线观看 | 另类国产精品一区二区 | 亚洲av日韩av无码污污网站 | 亚洲国产成人a精品不卡在线 | 亚洲AV无码A片一区二区三区 | 国产欧美日韩综合精品二区 | 欧洲亚洲精 | 吉泽明步高清无码中文 | 人妻少妇精品视中文字幕国语 | 少妇高潮惨叫久久久久电影69 | 成人精品综合免费视频 | 欧美乱妇狂野欧美在线视频 |