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() 方法,可以更方便地提取错误对象中的特定属性,并进行异常处理。这种方式可以使代码更加简洁和易读。

相关推荐
天外飞雨道沧桑21 小时前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
暗冰ཏོ1 天前
VUE面试题大全
前端·javascript·vue.js·面试
豹哥学前端1 天前
事件循环(Event Loop)深度解析:让你彻底搞懂 JS 的执行顺序
前端·javascript·面试
竹林8181 天前
用 wagmi v2 + Next.js 14 搞 NFT 交易市场前端:从合约调用失败到顺利上架,我踩了哪些坑
javascript·next.js
前端不开发1 天前
用一个 Bookmarklet(书签脚本),给任意网页挂一个可拖拽悬浮窗
前端·javascript
接着奏乐接着舞1 天前
【无标题】
开发语言·前端·javascript
雨雨雨雨雨别下啦1 天前
心理健康AI助手 - 项目总结
前端·javascript·vue.js·人工智能·信息可视化
风之舞_yjf1 天前
Vue基础(32)_TodoList案例
前端·javascript·vue.js
Amos_Web1 天前
Rspack 源码解析 (2) —— 从 rspack build 到输出 dist,完整编译链路详解
前端·javascript
张元清1 天前
Ref 逃生舱:用 React Hook 解决闭包陈旧、回调身份不稳和强制更新
前端·javascript·面试