日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

淺談JS三座大山之異步和單線程

瀏覽:169日期:2024-03-23 14:35:03
目錄單線程異步單線程

但是我們?cè)陂_(kāi)發(fā)中,遇到請(qǐng)求網(wǎng)絡(luò),或者定時(shí)任務(wù)的時(shí)候,如果等待網(wǎng)絡(luò)請(qǐng)求結(jié)束或者定時(shí)任務(wù)結(jié)束的時(shí)候再去做其他事情,這樣頁(yè)面就會(huì)卡住,所以js有異步機(jī)制解決這個(gè)問(wèn)題。

異步

異步的特點(diǎn)是不會(huì)阻塞后面的代碼執(zhí)行,當(dāng)同步任務(wù)執(zhí)行完畢之后,再執(zhí)行異步任務(wù)。相對(duì)的,同步會(huì)阻止代碼執(zhí)行。異步任務(wù)的應(yīng)用主要有網(wǎng)絡(luò)請(qǐng)求和定時(shí)任務(wù)。

異步是通過(guò)callback的方式實(shí)現(xiàn)的,在callback里面執(zhí)行異步執(zhí)行的代碼,但是有一些場(chǎng)景比如我們有三個(gè)網(wǎng)絡(luò)請(qǐng)求abc需要依次執(zhí)行,在a的回調(diào)里發(fā)起b請(qǐng)求,在b的回調(diào)里發(fā)起c請(qǐng)求,這樣會(huì)造成一種很混亂的寫(xiě)法,稱(chēng)之為回調(diào)地獄,可以試想一下,如果頁(yè)面邏輯過(guò)于復(fù)雜,需要依次調(diào)用10個(gè)接口,那么代碼的可讀性會(huì)非常非常差,我們?nèi)绻吹搅藙e人的這種代碼難免內(nèi)心奔跑一萬(wàn)只神獸。

promise基本用法:

let fun1 = function(flag){ return new Promise((resolve,reject)=>{ if(flag){setTimeout(() => {resolve('success')}, 1000); }else{setTimeout(() => {reject('fail')}, 1000); } })}fun1(true).then((res)=>{ console.log(res)//success}).catch((res)=>{ console.log(res)})fun1(false).then((res)=>{ console.log(res)}).catch((res)=>{ console.log(res)//fail})

上面是一個(gè)最簡(jiǎn)單的promise函數(shù),promise函數(shù)返回一個(gè)Promise對(duì)象,參數(shù)是一個(gè)函數(shù),接收兩個(gè)參數(shù)resolve和reject,這兩個(gè)參數(shù)也是函數(shù),當(dāng)執(zhí)行resolve()或者reject()的時(shí)候,函數(shù)返回.

如果執(zhí)行了resolve(),就會(huì)在調(diào)用的時(shí)候執(zhí)行then()方法,并接收resove()返回的參數(shù);

如果執(zhí)行了reject(),就會(huì)在調(diào)用的時(shí)候執(zhí)行catch()方法,并接收reject()返回的參數(shù);

用promise重新實(shí)現(xiàn)一下上面三個(gè)網(wǎng)絡(luò)請(qǐng)求的問(wèn)題:

let callService = function(url){ return new Promise((resolve,reject)=>{ axios.get(url).then((res)=>{ resolve(res) }).catch((err)=>{ reject(err) }) }) } const url1 = '/user/url1' const url2 = '/user/url2' const url3 = '/user/url3' callService(url1).then((res)=>{ // do something return callService(url2) }).then(()=>{ // do something return callService(url3) }).then((res)=>{ // do something }).catch((err)=>{ console.log(err) })

用上面的寫(xiě)法重新實(shí)現(xiàn)之后,寫(xiě)法上只會(huì)有一層,而不會(huì)陷入層層的回調(diào)之中。

promise.all

promise.all可以將多個(gè)promise包裝成一個(gè)新的實(shí)例,成功的時(shí)候返回一個(gè)數(shù)組,誰(shuí)先失敗返回誰(shuí)的值。

promise.all方法可以幫我們處理日常開(kāi)發(fā)中多接口同時(shí)調(diào)用的處理問(wèn)題。

let p1 = new Promise((resolve, reject) => { resolve(’成功了’)})let p2 = new Promise((resolve, reject) => { resolve(’success’)})Promise.all([p1, p2]).then((result) => { console.log(result) //[’成功了’, ’success’]}).catch((error) => { console.log(error)})

promise.race

這個(gè)方法的作用是多個(gè)接口賽跑,哪個(gè)跑得快就返回哪個(gè)

Promise.race([p1, p2]).then((result) => { console.log(result)}).catch((error) => { console.log(error) })

以上就是淺談JS三座大山之異步和單線程的詳細(xì)內(nèi)容,更多關(guān)于JS三座大山之異步和單線程的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产欧美一区二区三区精品酒店 | 老鸭窝亚洲一区二区三区| 久久久久久亚洲精品美女| 99亚洲视频| 欧美 日韩 国产一区二区在线视频| 日韩欧美精品一区| 91综合视频| 成人国产精品一区二区网站| 精品国产欧美日韩一区二区三区| 国产欧美另类| 国产伦理久久久久久妇女| 7777精品| 日韩av资源网| 国产欧美日韩一区二区三区四区 | 欧美日韩一区二区三区视频播放| 91亚洲一区| 国产成人77亚洲精品www| 国产精品草草| 四季av一区二区凹凸精品| 久久精品理论片| sm捆绑调教国产免费网站在线观看| 成人在线免费观看91| 理论片午夜视频在线观看| 久久久久伊人| 国产66精品| 成人影视亚洲图片在线| 精品国产免费人成网站| 99精品综合| 亚洲一区二区成人| 视频一区日韩| 国产激情精品一区二区三区| 精品九九久久| 欧美日一区二区| 国产精品婷婷| 青青草国产成人99久久| 精品午夜久久| 欧美日韩在线二区| 亚洲精品日韩久久| 免费在线亚洲| 日韩和的一区二在线| 久久中文字幕av| 日韩中文字幕不卡| 国产精品男女| 国产精品字幕| 亚洲一区二区av| 国产精品亚洲成在人线| 色婷婷亚洲mv天堂mv在影片| 欧美精品一区二区久久| 亚洲综合小说| 久久伊人亚洲| 欧美日韩激情在线一区二区三区| 亚洲乱码久久| 精品免费视频| 久久av在线| 欧美国产免费| 播放一区二区| 视频一区中文字幕精品| 精品五月天堂| 国产亚洲一区在线| 国产精品久久久久9999高清| 99久久婷婷| 日本欧美一区| 四虎4545www国产精品 | 午夜精品一区二区三区国产| 亚洲精品大全| 丁香六月综合| 日本成人中文字幕| 久久精品动漫| 欧美另类中文字幕| 日韩中文视频| 国产色噜噜噜91在线精品| 欧美一区二区性| 国产精品巨作av| 亚洲少妇在线| 精品午夜久久| 日本一区二区三区中文字幕| 欧美三区四区| 国产无遮挡裸体免费久久| 美女一区网站| 欧美日一区二区在线观看| 国产综合视频| 久久伊人国产| 日韩国产91| 九九久久电影| av日韩中文| 69精品国产久热在线观看| 亚洲午夜黄色| 精品国产午夜肉伦伦影院| 日韩一区二区三区精品| 免费久久精品| 中文av在线全新| 国产九一精品| 中文字幕中文字幕精品| 99国产精品免费视频观看| 国产一区二区三区四区五区传媒| 在线观看亚洲精品福利片| 欧美特黄一级大片| av中文字幕在线观看第一页| 国产精品任我爽爆在线播放| 日韩一区二区三区精品| 蜜臀av国产精品久久久久| 午夜久久黄色| 欧美1级日本1级| 在线人成日本视频| 麻豆高清免费国产一区| 国产日韩一区二区三区在线| 日本不卡视频一二三区| 亚洲丝袜美腿一区| 欧美不卡在线| 福利一区二区三区视频在线观看| 18国产精品| 亚洲人亚洲人色久| 欧美91视频| 久久久久久久久久久妇女| 国产极品模特精品一二| 亚洲免费资源| 亚州av乱码久久精品蜜桃| 另类小说一区二区三区| 一本一道久久a久久精品蜜桃| 国产传媒av在线| 国产乱码精品一区二区三区亚洲人 | 91麻豆国产自产在线观看亚洲| 美女精品在线| 99精品一区| 蜜桃成人av| 福利一区和二区| 久久wwww| 欧美日韩午夜| 亚洲性视频在线| 婷婷综合在线| 日韩午夜一区| 亚洲一级影院| 国产美女高潮在线| 欧美韩一区二区| 视频精品一区二区| 美女少妇全过程你懂的久久| 久久精品三级| 色一区二区三区四区| 国产亚洲人成a在线v网站| 老鸭窝毛片一区二区三区| 婷婷综合网站| 久久久久久免费视频| 国产91精品对白在线播放| 国产美女高潮在线观看| 欧美精品二区| 综合激情视频| 综合色就爱涩涩涩综合婷婷| 中文字幕免费一区二区| 亚洲欧洲一区| 日韩精品欧美激情一区二区| 精品三级国产| 国产福利91精品一区二区| 精品中国亚洲| 桃色av一区二区| 日韩欧美少妇| 热三久草你在线| 亚洲涩涩在线| 日韩欧美字幕| 久久精品导航| 中文字幕av一区二区三区四区| 香蕉久久久久久久av网站| 亚洲高清成人| 欧美日韩国产欧| 99国内精品| 狠狠久久婷婷| 午夜国产精品视频免费体验区| 免费在线看一区| 一区二区日韩免费看| 涩涩涩久久久成人精品| 日韩精品国产欧美| 久久国产日韩欧美精品| 国产精品久久久一区二区| 高清日韩中文字幕| 波多视频一区| 99久久99久久精品国产片果冰| 久久一区二区三区喷水| 99国产精品| 日韩一区二区三区精品视频第3页| 日本一不卡视频| 欧美一级一区| 免费日韩成人| 91亚洲国产高清| 婷婷亚洲五月| 亚洲三级网址| 国产精品地址| 日韩深夜视频| 婷婷成人基地| 亚洲精品在线二区| 国产精品v一区二区三区| 91成人福利| 久久伦理在线| 亚洲精品伊人| 精品久久美女| 中日韩男男gay无套| 国产精品视频一区二区三区| 日本а中文在线天堂| 黄色亚洲免费| 青草国产精品久久久久久| 欧美黑人做爰爽爽爽| 亚洲免费婷婷|