JS基于ES6新特性async await進(jìn)行異步處理操作示例
本文實例講述了JS基于ES6新特性async await進(jìn)行異步處理操作。分享給大家供大家參考,具體如下:
我們往往在項目中會遇到這樣的業(yè)務(wù)需求,就是首先先進(jìn)行一個ajax請求,然后再進(jìn)行下一個ajax請求,而下一個請求需要使用上一個請求得到的數(shù)據(jù),請求少了還好說,如果多了,就要一層一層的嵌套,就好像有點callback的寫法了,那是相當(dāng)惡心的,下面我就來講一下如何使用ES6的新特性async await進(jìn)行異步處理,使上述情況就好像寫同步代碼一樣,首先我們先舉個例子:
先寫上json文件:
code.json:
{
"code":0,
"msg":"成功"
}
person.json:
{
"code":0,
"list":[
{
"id":1,
"name":"唐僧"
},
{
"id":2,
"name":"孫悟空"
},
{
"id":3,
"name":"豬八戒"
},
{
"id":4,
"name":"沙僧"
}
]
}
比如我們有兩個請求,如下,這里用的axios:
function getCode(){
return axios.get('json/code.json');
}
function getlist(params){
return axios.get('json/person.json',{params})
}
我們第二個請求獲取列表的時候需要使用第一個請求得到的code值,只有code值為0時,才能請求,而且當(dāng)做參數(shù)傳進(jìn)去,那么我們看一下常規(guī)的做法吧
function getFinal(){
console.log("我是getFinal函數(shù)")
getCode().then(function(res){
if(res.data.code == 0){
console.log(res.data.code);
var params = {
code:res.data.code
}
getlist(params).then(function(res){
if(res.data.code == 0){
console.log(res.data.list);
}
})
}
})
}
getFinal();
看結(jié)果

雖然結(jié)果出來了,可是這種寫法真的挺難受的,下面來一個async await的寫法
async function getResult(){
console.log("我是getResult函數(shù)")
let code = await getCode();
console.log(code.data.code);
if(code.data.code == 0){
var params = {
code:code.data.code
}
let list = await getlist(params);
console.log(list.data.list);
}
}
getResult();
下面看結(jié)果

當(dāng)然還剩最后一點,處理異常,可以加上try catch
async function getResult(){
console.log("我是getResult函數(shù)")
try{
let code = await getCode();
console.log(code.data.code);
if(code.data.code == 0){
var params = {
code:code.data.code
}
let list = await getlist(params);
console.log(list.data.list);
}
}catch(err){
console.log(err);
}
}
getResult();
個人認(rèn)為做vue項目的時候,如果對于異常沒有特殊處理,可以不加try catch,因為打印出來的錯誤跟vue自己報的錯誤是一樣的,而且還是黑的字體,不如醒目的紅色來的痛快?。‘?dāng)然如果要對錯誤進(jìn)行特殊處理,那么就加上吧
代碼風(fēng)格是不是簡便了許多,而且異步代碼變成了同步代碼,下面我稍微講一下后者寫法的代碼執(zhí)行順序
首先在 function 前面加 async 用來說明這個函數(shù)是一個異步函數(shù),當(dāng)然,async是要和await配合使用的,第一個請求
let code = await getCode();
await 意思是等一下,等著getCode()這個函數(shù)執(zhí)行完畢,得到值后再賦值給code,然后再用code的值進(jìn)行下一步操作,就是這么簡單?。?!趕緊去改代碼??!
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
js實現(xiàn)網(wǎng)頁多級級聯(lián)菜單代碼
這篇文章主要介紹了js實現(xiàn)網(wǎng)頁多級級聯(lián)菜單代碼,涉及javascript基于數(shù)組動態(tài)構(gòu)造多級級聯(lián)菜單的技巧,非常具有實用價值,需要的朋友可以參考下2015-08-08
JS控制阿拉伯?dāng)?shù)字轉(zhuǎn)為中文大寫示例代碼
阿拉伯?dāng)?shù)字如何轉(zhuǎn)為中文大寫這個實現(xiàn)的方法有很多,在本文將為大家介紹下js中時如何實現(xiàn)的,感興趣的朋友可以參考下2013-09-09
js parseInt("08")未指定進(jìn)位制問題
今天在做JS關(guān)于月份的判斷,對于parseInt("01")到parseInt("07");都能得到正確的結(jié)果,但如果是parseInt("08")或parseInt("09")則返回0,首先看parseInt語法:parseInt(string, radix);2010-06-06
js實現(xiàn)Element中input組件的部分功能并封裝成組件(實例代碼)
這篇文章主要介紹了純生js實現(xiàn)Element中input組件的部分功能(慢慢完善)并封裝成組件,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
JavaScript實現(xiàn)多叉樹的遞歸遍歷和非遞歸遍歷算法操作示例
這篇文章主要介紹了JavaScript實現(xiàn)多叉樹的遞歸遍歷和非遞歸遍歷算法,結(jié)合實例形式詳細(xì)分析了JavaScript多叉樹針對json節(jié)點的遞歸與非遞歸遍歷相關(guān)操作技巧,需要的朋友可以參考下2018-02-02

