ES6中的async、await函数

async是为了解决异步操作,其实是一个语法糖,使代码书写更加简洁。

1. async介绍

async放在一个函数的前面,await则放在异步操作前面。async代表这个函数中有异步操作需要等待结果,在一个async函数中可以存在多个await,也就是多个异步操作,但是需要注意的是await是一个一个发生的,执行完一个异步操作才会执行下一个异步操作,不是并发执行的。

async结果返回一个Promise对象,async结果状态变化可以由三种情况改变

第一种:函数体内有return,return的结果可以通过then方法获取。

第二种:如果await中的异步操作状态变为reject,则会将错误外抛,改变async的状态变为reject。

第三种:当所有await都执行完,并且状态为resolved,则状态会变为resolved,也就是只有所有异步操作执行完,才会执行then方法获取。

2. async可以使用在哪里?

  • 函数声明中
js 复制代码
async function fun() {}
  • 函数表达式
js 复制代码
const fun = async function() {}
  • 对象的方法
js 复制代码
let obj = { async foo() {} };
obj.foo().then()
  • Class的方法
js 复制代码
class Person{
    async age(num) {
        const a = await foo();
    }
}
const p1 = new Person();
p1.age(10).then();
  • 箭头函数
js 复制代码
const foo = async () => {};

3. 使用

js 复制代码
const f1 = async () => {
    await ab();
}
f1.then((resolve) => {
    console.log(resolve);
})

4. 错误处理

await后面一个Promise对象,如果不是则会立即转成Promise对象。

假如有问题的时候会向外抛出错误,会导致async状态变为reject。

假如我们不需要往外抛错误,可以使用try...catch或者在异步操作中添加catch方法,让错误及时处理掉,不往外抛。

js 复制代码
async Function f1 () {
    await Promise.reject('出错了');
    await Promise.resolve('hello word'); // 不会执行了
}

由于抛出错误了,会整个async函数都会中断执行。

js 复制代码
// 改成 第一种解决方法

async Function f1 () {
    try {
        await Promise.reject('出错了');
    }catch (err){
    }
    return await Promise.resolve('hello word');
}

f1.then(res => console.log(res)); // hello word

// 第二种解决方法

async Function f1 () {
    await Promise.reject('出错了').catch((err) => {
        console.log(err);
    })
    return await Promise.resolve('hello world');
}
f1.then(res => console.log(res)); // 出错了  hello word

5. 并发执行代码

正常情况下当async函数内部都多个await时,会执行完一个异步操作才会执行下一个异步操作,是继发执行,而不是并发执行,这样会很慢。

如果await后面的异步操作没有关联的话,则可以完全同时触发。

  • 第一种使用Promise.all()方法
js 复制代码
let [foo, bar] = await Promise.all([getFoo(), getBar()]);
  • 第二种执行方法后await
js 复制代码
let fooPromise = getFoo();
let barPromise = getBar();
let foo = await fooPromise();
let bar = await barPromise();

这样会同时触发异步操作,缩短执行时间。

  • 第三种 for循环、不能map循环
js 复制代码
async function dbFuc (db) {
    let docs = [{}, {}, {}];
    let promises = docs.map(docs => db.post(doc));
    let results = [];
    for (let promise of promisees) {
        results.push(await promise);
    }
    console.log(results);
}
相关推荐
江城开朗的豌豆28 分钟前
React输入框优化:如何精准获取用户输入完成后的最终值?
前端·javascript·全栈
hqwest31 分钟前
C#WPF实战出真汁08--【消费开单】--餐桌面板展示
c#·wpf·ui设计·wpf界面设计
orangapple35 分钟前
WPF 打印报告图片大小的自适应(含完整示例与详解)
c#·wpf
江城开朗的豌豆37 分钟前
拆解Redux:从零手写一个状态管理器,彻底搞懂它的魔法!
前端·javascript·react.js
知识分享小能手6 小时前
Vue3 学习教程,从入门到精通,Axios 在 Vue 3 中的使用指南(37)
前端·javascript·vue.js·学习·typescript·vue·vue3
烛阴11 小时前
精简之道:TypeScript 参数属性 (Parameter Properties) 详解
前端·javascript·typescript
开发者小天12 小时前
为什么 /deep/ 现在不推荐使用?
前端·javascript·node.js
找不到工作的菜鸟14 小时前
Three.js三大组件:场景(Scene)、相机(Camera)、渲染器(Renderer)
前端·javascript·html
定栓14 小时前
vue3入门-v-model、ref和reactive讲解
前端·javascript·vue.js
binqian15 小时前
【异步】js中异步的实现方式 async await /Promise / Generator
开发语言·前端·javascript