m0_74144421 2023-04-04 22:38 采纳率: 66.7%
浏览 14
已结题

关于promise中使用try catch

为什么

async function main1() {
  try {
   await new Promise(() => {
      throw new Error('promise1 error')
    })
  } catch(e) {
    console.log(e.message);
  }
}

可以在catch中捕获错误

但是

function main1() {
  try {
    new Promise(() => {
      throw new Error('promise1 error')
    })
  } catch(e) {
    console.log(e.message);
  }
}

就捕获不呢

  • 写回答

2条回答 默认 最新

  • 2301_77345366 2023-04-05 09:05
    关注

    Promise是链式调用。第一个使用了语法糖async和await,这就导致所有的动作都暂停,等待Promise完成后再执行后续。
    第二个函数运行的时候。遇到Promise会启动一个新的微操作,而本函数已经运行完毕。
    如果要捕捉Promise的错误。应该以下方式操作:

    
    function main1() {
          new Promise(() => {
            throw new Error('promise1 error')
          }).then((result)=> {
            console.log(result);
          }).catch((e)=>{
            console.log(e.message);
          });
      }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月13日
  • 已采纳回答 4月5日
  • 创建了问题 4月4日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度