ES中的Async函数

在JavaScript中,async函数是一种使异步编程更加直观和易于理解的方式。它们是基于Promise的,并允许我们以同步的方式编写异步代码。

Async函数的基本概念

async函数是一种特殊类型的函数,可以说是异步操作的语法糖。它的全称是"异步函数",是ES2017标准引入的新语法,用于简化Promise的使用,并使异步代码看起来更像同步代码。

javascript 复制代码
async function foo() {
  // ...
}

在函数声明前面添加async关键字,就可以声明一个异步函数。异步函数总是返回一个Promise对象。如果函数体内有return语句,Promise的状态将变为resolved,并将return语句后的值作为其结果。如果函数体内抛出错误,则Promise的状态将变为rejected,并将错误对象作为其结果。

使用Async函数

基本用法

javascript 复制代码
async function foo() {
  return 'Hello, async';
}

foo().then(console.log);  // 输出: 'Hello, async'

在这个例子中,foo函数返回的Promise对象的状态变为resolved,并将字符串'Hello, async'作为其结果。

错误处理

javascript 复制代码
async function foo() {
  throw new Error('Something went wrong');
}

foo().catch(console.error);  // 输出: Error: Something went wrong

在这个例子中,foo函数返回的Promise对象的状态变为rejected,并将错误对象作为其结果。

Async/Await的组合使用

async/await的组合使用可以使我们的代码更加清晰和易于理解。await关键字只能在async函数中使用,它会暂停代码的执行,直到Promise被解决或拒绝。

javascript 复制代码
async function foo() {
  let response = await fetch('https://api.github.com/users/github');
  let user = await response.json();
  console.log(user.name);
}

foo();

在这个例子中,我们使用await关键字等待fetch方法返回的Promise被解决,然后再继续执行后面的代码。

Async函数的技巧

使用try/catch进行错误处理

javascript 复制代码
async function foo() {
  try {
    let response = await fetch('https://api.github.com/users/github');
    let user = await response.json();
    console.log(user.name);
  } catch (error) {
    console.error(`Error: ${error}`);
  }
}

foo();

在这个例子中,我们使用try/catch语句来处理可能出现的错误。如果fetchresponse.json方法抛出错误,我们可以在catch块中处理它。

使用Promise.all处理多个异步操作

javascript 复制代码
async function foo() {
  try {
    let [userResponse, reposResponse] = await Promise.all([
      fetch('https://api.github.com/users/github'),
      fetch('https://api.github.com/users/github/repos')
    ]);

    let user = await userResponse.json();
    let repos = await reposResponse.json();

    console.log(user.name);
    console.log(repos.length);
  } catch (error) {
    console.error(`Error: ${error}`);
  }
}

foo();

在这个例子中,我们使用Promise.all方法来同时处理多个异步操作。这样,我们可以在所有异步操作完成后一次性获取所有结果。

相关推荐
namexingyun8 分钟前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程
Zyed12 分钟前
[STM32]Day15读写FLASH+读取ID
前端·stm32·性能优化
jvxiao1 小时前
你真的懂作用域吗?从编译原理角度深度 JS 的作用域
前端·javascript
Darling噜啦啦1 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
星栈1 小时前
Rust + Makepad 应用怎么打包发布:Windows、macOS、Linux 全平台交付
前端·rust
YHHLAI1 小时前
从零搭建一个 RESTful Todo 服务 —— Bun + TypeScript 全栈最小闭环
后端·typescript·restful
Aolith1 小时前
React 路由守卫:我用一个组件替代了 Vue 的 beforeEach
前端·react.js
Daybreak1 小时前
从 PDD、DDD、SDD 到 TDD:我是如何用一套 Agent 工程方法论推进 My-Notion 的
前端
退休倒计时2 小时前
【每日一题】LeetCode 19. 删除链表的倒数第 N 个结点 TypeScript
leetcode·链表·typescript
HjhIron2 小时前
从零实现一个待办事项应用:前端必学的Ajax与Node.js实战
前端·后端