await 能够理解为是 async wait 的简写。await 必须出如今 async 函数内部,不能单独使用。 函数中只要使用await,则当前函数必须使用async修饰
ajax
在真实开发中,你有三个请求须要发生,第三个请求是依赖于第二个请求的解构第二个请求依赖于第一个请求的结果。promise
若用 ES5实现会有3层的回调, 若用Promise 实现至少须要3个then。
一个是代码横向发展,另外一个是纵向发展。 今天主角是 async-await 的实现哈~浏览器
//咱们仍然使用 setTimeout 来模拟异步请求
function sleep(second, param) {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve(param);
}, second);
})
}
async function test() {
let result1 = await sleep(2000, 'req01');
console.log(` ${result1}`);
let result2 = await sleep(1000, 'req02' + result1);
console.log(` ${result2}`);
let result3 = await sleep(500, 'req03' + result2);
console.log(` ${result3}`);
}
test();
<!-- 输出
Promise {<pending>}
__proto__: Promise
[[PromiseStatus]]: "resolved"
[[PromiseValue]]: undefined
VM913:14
req01
req02req01
req03req02req01
-->
复制代码
上面的都是 resolved 的状况,那么 reject 的处理呢bash
为了处理Promise.reject 的状况咱们应该将代码块用 try catch 包裹一下
function sleep(second) {
return new Promise((resolve, reject) => {
setTimeout(() => {
reject('want to sleep~');
}, second);
})
}
async function errorDemo() {
let result = await sleep(1000);
console.log(result);
}
errorDemo();// VM706:11 Uncaught (in promise) want to sleep~
// 为了处理Promise.reject 的状况咱们应该将代码块用 try catch 包裹一下
async function errorDemoSuper() {
try {
let result = await sleep(1000);
console.log(result);
} catch (err) {
console.log(err);
}
}
errorDemoSuper();// want to sleep~
// 有了 try catch 以后咱们就可以拿到 Promise.reject 回来的数据了。复制代码
对于初学者来讲一不当心就将 ajax 的并发请求发成了阻塞式同步的操做了,我就真真切切的在工做中写了这样的代码。await 若等待的是 promise 就会中止下来。真实业务是这样的,我有三个异步请求须要发送,相互没有关联,只是须要当请求都结束后将界面的 loading 清除掉便可。 刚学完 async await 开心啊,处处乱用~并发
function sleep(second) {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve('request done! ' + Math.random());
}, second);
})
}
async function bugDemo() {
await sleep(1000);
await sleep(1000);
await sleep(1000);
console.log('clear the loading~');
}
bugDemo(); // 等待一会输出 clear the loading~
复制代码
loading 确实是等待请求都结束完才清除的。可是你认真的观察下浏览器的 timeline 请求是一个结束后再发另外一个的(若观察效果请发真实的 ajax 请求)dom
async function correctDemo() {
let p1 = sleep(1000);
let p2 = sleep(1000);
let p3 = sleep(1000);
await Promise.all([p1, p2, p3]);
console.log('clear the loading~');
}
correctDemo();// clear the loading~
复制代码