搜尋

首頁  >  問答  >  主體

使用 Async/Await 與 .then()

我對 async/await 的概念有點困惑,特別是當它與函數中的 .then() 相比時。

我目前正在使用一個基本的 React 應用程序,並在 useEffect 中獲取一些數據

我想知道,由於fetch 返回Promise ,為什麼在執行以下範例時我不需要將任何內容標記為asyncawait

useEffect(() => {
    fetch("whatever").then(res => console.log(res));
  }, [])

但是當我選擇執行 await 時,我需要將程式碼包裝在 async 函數中

useEffect(() => {
    // error, needs to be in an async function
    const res = await fetch("whatever");
  },[])

我想我的問題實際上是使用.then() 與使用async await 連結之間有什麼區別,為什麼. then() 不需要我等待任何東西,即使獲取回傳一個承諾? < /p>

謝謝

P粉545682500P粉545682500341 天前515

全部回覆(1)我來回復

  • P粉426906369

    P粉4269063692024-02-04 11:38:47

    要加入到@HEllRZA,then() 和 async/await 都可以用來處理 JavaScript 中的 Promise。 then() 是一種採用回呼函數作為參數的方法,並允許您連結多個 then() 方法來按順序處理回應。 Async/await 是一種在 JavaScript 中編寫非同步程式碼的新方法。

    回覆
    0
  • 取消回覆