Appearance
异步编程-async
date: 2020-05-30 16:46:12 tags: [js, 异步编程]
async 函数就是 Generator 函数的语法糖。
async 函数的用法
同 Generator 函数一样,async 函数返回一个 Promise 对象,可以使用 then 方法添加回调函数。当函数执行的时候,一旦遇到 await 就会先返回,等到触发的异步操作完成,再接着执行函数体内后面的语句。
async 函数内部 return 返回的值。会成为 then 方法回调函数的参数。
javascript
async function f() {
return 'hello world'
};
f().then( (v) => console.log(v)) // hello world如果 async 函数内部抛出异常,则会导致返回的 Promise 对象状态变为 reject 状态。抛出的错误而会被 catch 方法回调函数接收到。
javascript
async function e(){
throw new Error('error');
}
e().then(v => console.log(v))
.catch( e => console.log(e));async 函数返回的 Promise 对象,必须等到内部所有的 await 命令的 Promise 对象执行完,才会发生状态改变
也就是说,只有当 async 函数内部的异步操作都执行完,才会执行 then 方法的回调。
正常情况下,await 命令后面跟着的是 Promise ,如果不是的话,也会被转换成一个 立即 resolve 的 Promise
javascript
async function f() {
return await 1
};
f().then( (v) => console.log(v)) // 1如果返回的是 reject 的状态,则会被 catch 方法捕获。
错误处理
javascript
let a;
async function myFunction() {
try {
await somethingThatReturnsAPromise();
} catch (err) {
console.log(err);
}
}
// 另一种写法
async function myFunction() {
await somethingThatReturnsAPromise().catch(function (err){
console.log(err);
});
}