深刻理解 async / await

1、认识async

ES7 提出的async函数,终于让 JavaScript 对于异步操做有了终极解决方案。No more callback hellasync函数是 Generator函数的语法糖。使用 关键字 async 来表示,在函数内部使用 await来表示异步。html

先说一下async的用法,它做为一个关键字放到函数前面,用于表示函数是一个异步函数,由于async就是异步的意思, 异步函数也就意味着该函数的执行不会阻塞后面代码的执行。 写一个async 函数bash

async function timeout() {
  return 'hello world';
}
复制代码

2、语法

async 函数返回一个 Promise 对象异步

async 函数内部 return 返回的值。会成为 then 方法回调函数的参数。async

async function timeout() {
   return 'hello world';
}

timeout().then((v) => {
   console.log(v)
})

复制代码

若是 async 函数内部抛出异常,则会致使返回的 Promise 对象状态变为 reject 状态。抛出的错误而会被 catch 方法回调函数接收到。函数

async function e(){
   throw new Error('error');
}
e().then(v => console.log(v))
.catch( e => console.log(e));
复制代码

async 函数返回的 Promise 对象,必须等到内部全部的 await 命令的 Promise 对象执行完,才会发生状态改变post

也就是说,只有当 async 函数内部的异步操做都执行完,才会执行 then 方法的回调。ui

const delay = timeout => new Promise(resolve=> setTimeout(resolve, timeout));
async function f(){
    await delay(1000);
    await delay(2000);
    await delay(3000);
    return 'done';
}

f().then(v => console.log(v)); // 等待6s后才输出 'done'
复制代码

正常状况下,await 命令后面跟着的是 Promise ,若是不是的话,也会被转换成一个 当即 resolvePromise 以下面这个例子:spa

async function f() {
    return await 1
};
f().then( (v) => console.log(v)) // 1
复制代码

3、Async 函数的错误处理

先来看下面的例子:code

let a;
async function f() {
    await Promise.reject('error');
    a = await 1; // 这段 await 并无执行
}
f().then(v => console.log(a));
复制代码

当 async 函数中只要一个 await 出现 reject 状态,则后面的 await 都不会被执行。解决办法:能够添加 try/catch。htm

// 正确的写法
let a;
async function correct() {
    try {
        await Promise.reject('error')
    } catch (error) {
        console.log(error);
    }
    a = await 1;
    return a;
}
correct().then(v => console.log(a)); 
复制代码

参考文章

理解 async/await

用 async/await 来处理异步

相关文章
相关标签/搜索