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

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

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

在 JavaScript 中,fetch API 是一種常見(jiàn)的 HTTP 請(qǐng)求工具,但其需要兩次 await 的機(jī)制可能讓初學(xué)者感到疑惑。本文將通過(guò)示例與解析,理解這一特性。


基礎(chǔ)示例

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

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

Fetch 的兩階段流程

1. 獲取響應(yīng)

調(diào)用 fetch 時(shí),它返回一個(gè) Promise,在網(wǎng)絡(luò)請(qǐng)求完成后解析為 Response 對(duì)象:

  • 僅獲取元數(shù)據(jù):此時(shí)只獲取響應(yīng)頭信息,正文尚未處理。

2. 解析響應(yīng)正文 ??

Response 對(duì)象包含的方法(如 .json().text())用于讀取正文,這些方法返回另一個(gè) Promise,因?yàn)樽x取和解析正文是異步操作。


第一次 await 的內(nèi)部流程

當(dāng)你執(zhí)行以下代碼:

const response = await fetch(url);

1. 發(fā)送請(qǐng)求

瀏覽器向指定 URL 發(fā)起網(wǎng)絡(luò)請(qǐng)求:

  • 解析域名
  • 建立 TCP 連接
  • 發(fā)送 HTTP 請(qǐng)求

2. 接收響應(yīng)元數(shù)據(jù)

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

3. 構(gòu)造 Response 對(duì)象

  • 包含元數(shù)據(jù)的 Response 對(duì)象被創(chuàng)建:
    • Headers:通過(guò) response.headers 獲取。
    • Body:正文仍是未處理的可讀流。

第二次 await 的內(nèi)部流程

當(dāng)你執(zhí)行以下代碼:

const data = await response.json();

1. 讀取正文流

Response 對(duì)象的正文被解析為流:

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

2. 異步解析

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

3. 返回解析結(jié)果

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

為什么需要兩次 await

兩次 await 是 Fetch 的設(shè)計(jì)邏輯,分別解決以下問(wèn)題:

  1. **第一次 await**:

    • 等待網(wǎng)絡(luò)請(qǐng)求完成,獲取 Response 對(duì)象(包含狀態(tài)碼、頭信息等元數(shù)據(jù))。
  2. **第二次 await**:

    • 異步讀取和解析響應(yīng)正文,確保數(shù)據(jù)可用。

如果跳過(guò)任意一次 await 會(huì)如何?

  • **跳過(guò)第一次 await**:
    • 你將得到一個(gè)未解析的 Promise,而非 Response 對(duì)象。
  • **跳過(guò)第二次 await**:
    • 你將得到未解析的 Promise,而非解析后的數(shù)據(jù)。

完整示例:帶錯(cuò)誤處理

以下是一個(gè)完整的示例,展示如何正確處理錯(cuò)誤:

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);
}

錯(cuò)誤處理注意點(diǎn):

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

常見(jiàn)問(wèn)題與解決方案

1. 忘記錯(cuò)誤處理

  • 問(wèn)題fetch 默認(rèn)不會(huì)對(duì) HTTP 錯(cuò)誤拋出異常,可能導(dǎo)致你誤以為請(qǐng)求成功。
  • 解決:手動(dòng)檢查 response.ok 或 response.status

2. 忘記第二次 await

  • 問(wèn)題:會(huì)導(dǎo)致代碼處理未解析的 Promise,而非實(shí)際數(shù)據(jù)。
  • 解決:始終 await 解析方法(如 .json())。

3. 舊 API 的影響

  • 問(wèn)題:從 XMLHttpRequest 等同步 API 遷移的開(kāi)發(fā)者可能預(yù)期同步行為。
  • 解決:理解并適應(yīng) fetch 的 Promise 異步設(shè)計(jì)。

總結(jié)

使用 Fetch API 時(shí),兩次 await 是其異步設(shè)計(jì)的結(jié)果:

  1. **第一次 await**:確保接收到響應(yīng)元數(shù)據(jù)。
  2. **第二次 await**:解析響應(yīng)正文,獲取最終數(shù)據(jù)。

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

?

閱讀原文:原文鏈接


該文章在 2024/12/30 14:37:42 編輯過(guò)
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專(zhuān)業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車(chē)隊(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)性、管理的有效性于一體,是物流碼頭及其他港口類(lèi)企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷(xiāo)售管理,采購(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í)間、不限用戶(hù)的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
一区二区三区在线观看亚洲 | 日本三级香港少妇 | 五月天丁香婷婷最新 | 中文字幕AV制服丝袜电影 | 亚洲日韩性一区二区三区 | 亚洲国产精品人久久 |