關(guān)于js異步的寫法

關(guān)鍵字: Promise js異步 vue
參考文章:
http://www.ruanyifeng.com/blog/2012/12/asynchronous%EF%BC%BFjavascript.html
https://blog.csdn.net/shan1991fei/article/details/78966297
https://blog.csdn.net/hey_zng/article/details/75151853
https://segmentfault.com/a/1190000010420744

背景

最近寫前端業(yè)務(wù)严卖,需要順序請(qǐng)求多個(gè)api正驻,因此研究了一下比較好的異步寫法。在此記錄俘闯。

Promise.then寫法

  1. 一般寫法
  • Promise對(duì)象在new 的時(shí)候接收function類型的參數(shù)
  • .then函數(shù)接收一個(gè)function類型的參數(shù),該function需要返回一個(gè)Promise對(duì)象
  • .then中的回調(diào)函數(shù)如果有返回值侥袜,會(huì)作為下一個(gè).then回調(diào)函數(shù)的輸入;如果沒有返回值募胃,則默認(rèn)返回undefined
  1. 循環(huán)內(nèi)的使用
  • 先執(zhí)行for循環(huán),然后才會(huì)異步調(diào)用then里的promise畦浓,所以需要如下的執(zhí)行方式:
var pList= [];
for (var i = 0; i < 10; i++) {
    pList.push(createPromise());//放入Promise對(duì)象
}
Promise.all(pList)
    .then(function(responses) { //這邊的then接收的是之前所有all函數(shù)的執(zhí)行結(jié)果痹束,是一個(gè)list
        for (i = 0; i < responses.length; i++)
            console.log(responses[i].data);
        }

    )

關(guān)于Promise對(duì)象的個(gè)人體會(huì)

promise語法的本質(zhì)是為了方便寫回調(diào)函數(shù)

例子:

var p = new Promise( _ => {
    {一段異步代碼}
})
p.then( r => {
  console.log('callback');
})

等價(jià)于:

new Promise( _ => {
    {一段異步代碼}
    {console.log('callback');}
})
  • promise的寫法保證執(zhí)行完{異步代碼}后再執(zhí)行之后的內(nèi)容。
  • 每個(gè).then函數(shù)可以理解為向上一個(gè)Promise對(duì)象的function中嵌套代碼

個(gè)人實(shí)踐中總結(jié)出的結(jié)構(gòu)化寫法

在VUE中按面向?qū)ο蟮乃悸穼懏惒讲糠?/h5>
  • fileX.js中定義了class A
export class A {
    constructor() {this.str = '請(qǐng)求api...'}
    load() { //模擬api異步請(qǐng)求(VUE中的request對(duì)象)
        return new Promise(function(resolve, reject) {
            setTimeout(resolve, 1000, 'aaaa')}
        ).then(_=>console.log(this.str))
    }
}
  • 如下寫法可以保證執(zhí)行順序以及函數(shù)的閉包環(huán)境(直接寫.then(a.load)會(huì)導(dǎo)致load函數(shù)中的this對(duì)象丟失):
let a = new A()
let b = new A()
a.load().then( _ => b.load())
    .then(_=>console.log('asasas'))
使用async-await關(guān)鍵字代替.then的寫法

async 關(guān)鍵字作用于function讶请,從而在函數(shù)內(nèi)可以使用await關(guān)鍵字標(biāo)識(shí)異步方法

f_say = function(timeout, str) { //對(duì)應(yīng)api
    return new Promise(function(resolve, reject) {setTimeout(resolve, timeout, str)} )
}
f_test1 = async function(timeout, str) { //對(duì)應(yīng)api請(qǐng)求與處理函數(shù)
    const v = await f_say(timeout, str)
    console.log(v)
}
f_test = async function(){ //對(duì)應(yīng)外部順序業(yè)務(wù)
    await f_test1(1000, 'aaaa');
    console.log('!a!');
    await f_test1(100, 'bbbb');
    console.log('!b!');
    await f_test1(5000, 'cccc');
    console.log('!c!');
}
f_test()

可以保證f_test()函數(shù)中的各語句順序執(zhí)行

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末祷嘶,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子夺溢,更是在濱河造成了極大的恐慌论巍,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件风响,死亡現(xiàn)場(chǎng)離奇詭異嘉汰,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)状勤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門鞋怀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人持搜,你說我怎么就攤上這事密似。” “怎么了朵诫?”我有些...
    開封第一講書人閱讀 158,369評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵辛友,是天一觀的道長。 經(jīng)常有香客問我剪返,道長废累,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,799評(píng)論 1 285
  • 正文 為了忘掉前任脱盲,我火速辦了婚禮邑滨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘钱反。我一直安慰自己掖看,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評(píng)論 6 386
  • 文/花漫 我一把揭開白布面哥。 她就那樣靜靜地躺著哎壳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪尚卫。 梳的紋絲不亂的頭發(fā)上归榕,一...
    開封第一講書人閱讀 50,096評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音吱涉,去河邊找鬼刹泄。 笑死外里,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的特石。 我是一名探鬼主播盅蝗,決...
    沈念sama閱讀 39,159評(píng)論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼姆蘸!你這毒婦竟也來了墩莫?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,917評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤乞旦,失蹤者是張志新(化名)和其女友劉穎贼穆,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兰粉,經(jīng)...
    沈念sama閱讀 44,360評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評(píng)論 2 327
  • 正文 我和宋清朗相戀三年顶瞳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了玖姑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,814評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡慨菱,死狀恐怖焰络,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情符喝,我是刑警寧澤闪彼,帶...
    沈念sama閱讀 34,509評(píng)論 4 334
  • 正文 年R本政府宣布,位于F島的核電站协饲,受9級(jí)特大地震影響畏腕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜茉稠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評(píng)論 3 317
  • 文/蒙蒙 一描馅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧而线,春花似錦铭污、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至誓竿,卻和暖如春磅网,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背烤黍。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評(píng)論 1 267
  • 我被黑心中介騙來泰國打工知市, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留傻盟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,641評(píng)論 2 362
  • 正文 我出身青樓嫂丙,卻偏偏與公主長得像娘赴,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子跟啤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評(píng)論 2 351