亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

將 .catch 與異步等待一起使用會導致問題嗎?

將 .catch 與異步等待一起使用會導致問題嗎?

白板的微信 2022-05-22 10:28:07
我的問題是,將 .catch 與 async await 一起使用會導致問題嗎?例如:function f1() {  return new Promise((res, rej) => {    rej(1)  })}async function f2() {  await f1().catch(ex => { }) // this is what I mean}f2()
查看完整描述

2 回答

?
眼眸繁星

TA貢獻1873條經驗 獲得超9個贊

這取決于您對“問題”的含義,但是這段代碼:


async function f2() {

  await f1().catch(ex => { /* ... code in catch ... */ }) // this is what I mean

}

相當于:


async function f2() {

  try {

    await f1()

  } catch (ext) {

    /* ... code in catch ... */

  } // this is what I mean

}

.catch正如您所說,使用它而不是按try-catch原樣使用可能很有用- 并非在每種情況下 - 都可以使您的代碼更具可讀性。但是您需要始終考慮是否.catch是可讀性的正確選擇。如果您將它用于可恢復的錯誤處理,它會很好地工作。


查看完整回答
反對 回復 2022-05-22
?
BIG陽

TA貢獻1859條經驗 獲得超6個贊

我想你要找的是這個


function f1(){

  return new Promise((res,rej)=>{

    rej(1)

  })

}


async function f2(){

  try {

    const response = await f1();

    // use the response from f1()

  } catch(err) {

    throw new Error(err);

  }

}


f2()

沿著這些思路的東西async/await是承諾的包裝,允許您編寫看起來同步的代碼。否則你會看


function f2(){

  let response;

  f1().then(res => {

    response = res

  })

  .catch(err => {

    throw Error(err)

  });

}


查看完整回答
反對 回復 2022-05-22
  • 2 回答
  • 0 關注
  • 102 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號