網站首頁 Vue 正文
Vue的同步調用和異步調用
Promise實現異步調用
異步調用,增加a、b兩個方法,并在mounted中調用。 觀察客戶端,并沒有按照方法執行的順序輸出,使用Promise實現了異步調用。
觀察客戶端,并沒有按照方法執行的順序輸出,使用Promise實現了異步調用。
async /await方法實現同步調用
使用async 和 await配合promise也可以實現同步調用,nuxt.js中使用async/await實現同步調用效果
觀察服務端控制臺發現是按照a,b的調用順序輸出1,2,使用async/await實現了同步調用。
Vue同步和異步的問題
之所以想到寫這個問題是因為在工作中遇到一些相關的問題,最后用ES7的async-await 來解決這個問題。話不多述 ,進正題。
基本語法
async functionbasicDemo() { ????let result = await Math.random(); ????console.log(result); } basicDemo(); // 0.6484863241051226//Promise {[[PromiseStatus]]: "resolved", [[PromiseValue]]: undefined}
上述代碼就是async-await的基本使用形式。有兩個陌生的關鍵字async、await,同時函數執行結果似乎返回了一個promise對象。
async
async functiondemo01(){ ????return 123; } demo01().then(val=> { ????console.log(val);// 123});
若 async 定義的函數有返回值,return 123;相當于Promise.resolve(123),沒有聲明式的 return則相當于執行了Promise.resolve();
await
await 可以理解為是 async wait 的簡寫。await 必須出現在 async 函數內部,不能單獨使用。
functionnotAsyncFunc(){ ????await Math.random(); } notAsyncFunc();//Uncaught SyntaxError: Unexpected identifier
await 后面可以跟任何的JS 表達式。雖然說 await 可以等很多類型的東西,但是它最主要的意圖是用來等待 Promise 對象的狀態被 resolved。如果await的是 promise對象會造成異步函數停止執行并且等待?promise 的解決,如果等的是正常的表達式則立即執行。
functionsleep(second){ ????return new Promise((resolve, reject) => { ????????setTimeout(()=> { ????????????resolve(' enough sleep~'); ????????}, second); ????}) }functionnormalFunc(){ ????console.log('normalFunc'); }async functionawaitDemo(){ ????await normalFunc(); ????console.log('something, ~~'); ????let result = await sleep(2000); ????console.log(result);// 兩秒之后會被打印出來} awaitDemo()
希望通過上面的 demo,大家可以理解我上面的話。
實例
舉例說明啊,你有三個請求需要發生,第三個請求是依賴于第二個請求的解構第二個請求依賴于第一個請求的結果。若用 ES5實現會有3層的回調,若用Promise 實現至少需要3個then。一個是代碼橫向發展,另一個是縱向發展。今天指給出 async-await 的實現哈~
我們仍然使用 setTimeout 來模擬異步請求
functionsleep(second, param){ ????return new Promise((resolve, reject) => { ????????setTimeout(()=> { ????????????resolve(param); ????????}, second); ????}) }async functiontest(){ ????let result1 = await sleep(2000, 'req01'); ????let result2 = await sleep(1000, 'req02' + result1); ????let result3 = await sleep(500, 'req03' + result2); ????console.log(`${result3}${result2}${result1}`); } test();
錯誤處理
上述的代碼好像給的都是resolve的情況,那么reject的時候我們該如何處理呢?
functionsleep(second){ ????return new Promise((resolve, reject) => { ????????setTimeout(()=> { ????????????reject('want to sleep~'); ????????}, second); ????}) }async functionerrorDemo(){ ????let result = await sleep(1000); ????console.log(result); } errorDemo();// VM706:11 Uncaught (in promise) want to sleep~// 為了處理Promise.reject 的情況我們應該將代碼塊用 try catch 包裹一下async functionerrorDemoSuper(){ ????try { ????????let result = await sleep(1000); ????????console.log(result); ????} catch (err) { ????????console.log(err); ????} } errorDemoSuper();// want to sleep~
小心你的并行處理!!!
我這里為啥加了三個感嘆號呢~,因為對于初學者來說一不小心就將 ajax 的并發請求發成了阻塞式同步的操作了,我就真真切切的在工作中寫了這樣的代碼。await 若等待的是 promise 就會停止下來。業務是這樣的,我有三個異步請求需要發送,相互沒有關聯,只是需要當請求都結束后將界面的 loading 清除掉即可。 剛學完 async await 開心啊,到處亂用~
functionsleep(second){ ????return new Promise((resolve, reject) => { ????????setTimeout(()=> { ????????????resolve('request done! ' + Math.random()); ????????}, second); ????}) }async functionbugDemo(){ ????await sleep(1000); ????await sleep(1000); ????await sleep(1000); ????console.log('clear the loading~'); } bugDemo();
loading 確實是等待請求都結束完才清除的。但是你認真的觀察下瀏覽器的 timeline 請求是一個結束后再發另一個的(若觀察效果請發真實的 ajax 請求)
那么,正常的處理是怎樣的呢?
async functioncorrectDemo(){ ????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~
以上。?
原文鏈接:https://blog.csdn.net/qq_37808895/article/details/104628448
相關推薦
- 2022-12-21 Android?RecyclerView四級緩存源碼層詳細分析_Android
- 2022-10-08 ASP.NET泛型三之使用協變和逆變實現類型轉換_實用技巧
- 2023-07-30 ES6 module語法中export和import的使用
- 2022-08-18 python編寫第一個交互程序步驟示例教程_python
- 2023-01-28 詳解如何利用C#實現漢字轉拼音功能_C#教程
- 2022-04-11 左DIV寬度固定,右DIV適應剩下的寬度
- 2022-11-30 Rust實現面向對象的方法_Rust語言
- 2022-05-18 centos?自動運行python腳本和配置?Python?定時任務_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支