async&await方法中异常如何处理?

  • try catch可以,比较方便
  • .catch也可以
  • .catch配合析构赋值也可以,比较优雅

在 async/await 方法中,可以使用 try-catch 块来处理异常。通过使用 try-catch,可以捕获异步操作中抛出的异常,并在 catch 块中进行适当的处理。

下面是一个 async/await 方法中使用 try-catch 处理异常的示例:

javascript 复制代码
async function fetchData() {
  try {
    const response = await fetch("https://api.example.com/data");
    if (!response.ok) {
      throw new Error("Request failed");
    }
    const data = await response.json();
    return data;
  } catch (error) {
    console.error("Error:", error);
    throw error; // 可以选择重新抛出异常
  }
}

async function process() {
  try {
    const result = await fetchData();
    console.log("Result:", result);
  } catch (error) {
    console.error("Error:", error);
  }
}

process();

在上述示例中,fetchData 函数是一个异步函数,内部使用 await 关键字等待 fetch 方法返回的 Promise 对象。如果请求失败(response.ok 为 false),则使用 throw 关键字抛出一个错误。在 catch 块中,可以捕获和处理这个错误,并进行适当的操作,比如打印错误信息或重新抛出异常。

在 process 函数中,使用 try-catch 块来捕获 fetchData 函数可能抛出的异常。如果 fetchData 函数中的异常被捕获到,则会在 catch 块中进行处理。

需要注意的是,在 async/await 方法中,如果不使用 try-catch 来处理异常,异步操作中抛出的错误将会被包装成一个被拒绝(rejected)的 Promise 对象,可以通过在调用 async 函数时使用 catch 方法来捕获这个错误。

async/await 方法提供了一种更直观和简洁的方式来处理异步操作,并且可以方便地使用 try-catch 来处理异常,使代码更易读和易于维护。

在 async/await 方法中,可以使用 .catch() 方法结合析构赋值(Destructuring Assignment)来进行异常处理。

下面是一个示例,展示了如何使用析构赋值和 .catch() 方法来处理异常:

javascript 复制代码
async function fetchData() {
  const response = await fetch("https://api.example.com/data");
  if (!response.ok) {
    throw new Error("Request failed");
  }
  const data = await response.json();
  return data;
}

async function process() {
  try {
    const result = await fetchData();
    console.log("Result:", result);
  } catch ({ message }) {
    console.error("Error:", message);
  }
}

process().catch(error => {
  console.error("Unhandled error:", error);
});

在上述示例中,fetchData 函数是一个异步函数,内部使用 await 关键字等待 fetch 方法返回的 Promise 对象。如果请求失败(response.ok 为 false),则使用 throw 关键字抛出一个错误。

在 process 函数中,使用 try-catch 块来捕获 fetchData 函数可能抛出的异常。在 catch 块中,使用析构赋值将错误对象的 message 属性解构出来,并进行适当的处理。

在调用 process 函数时,可以使用 .catch() 方法来捕获未处理的异常。这样可以确保在异步操作中抛出的异常能够被正确地捕获和处理。

通过使用析构赋值和 .catch() 方法,可以更方便地提取错误对象中的特定属性,并进行异常处理。这种方式可以使代码更加简洁和易读。

相关推荐
大家的林语冰7 分钟前
ESLint 近期动态大全,新版本正式发布,antfu 大佬推荐的插件也更新了!
前端·javascript·前端工程化
胡志辉1 小时前
深入浅出 call、apply、bind
前端·javascript·后端
十九画生4 小时前
parentID ``` JavaScript 是区分大小写的,所以这两个不是同一个字段。 第二,`parent` 没有声明。 应该先写: `
javascript
怕浪猫4 小时前
Electron 开发实战(十六):总结与展望|生态现状、框架对比、行业趋势与学习指南
前端·javascript·electron
ZengLiangYi5 小时前
批量导入 1000 条对话的性能优化实战
javascript·后端·架构
竹林8186 小时前
用 wagmi v2 + viem 监听合约事件时踩的坑,我花了两天才把"遗漏事件"修好
javascript
小花酱酱6 小时前
QQ群里只有你一个人?邪门歪道破局之路——AstrBot
javascript
bonechips6 小时前
JS 数组指南:从内存原理到二维矩阵
前端·javascript
mONESY6 小时前
前端零基础精讲:Canvas3D、CSS3D、文档流、定位全方位复盘
javascript