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~
複製代碼