【React.js 22】async+await異步操作

ES2017新增async語(yǔ)法初家,用一種很優(yōu)雅的方式去實(shí)現(xiàn)了異步操作清酥,具體講解可以參照阮一峰大神的文章购公。

以往的異步操作,都是使用callback的方式去實(shí)現(xiàn)泊交,例如setTimeout()函數(shù)乳讥,一旦互相依賴的事件多了,這種方式就很容易造成callback hell廓俭,不易讀云石,很不友好:

setTimeout(()=>{
  console.log(x)
  setTimeout(()=>{
    console.log(xx)
    setTimeout(()=>{
      console.log(xxx)
    },1)
  },1)
},1)

于是乎,又有了Promise對(duì)象研乒,雖然在很大程度上讓代碼易讀性提高了汹忠,但是一旦依賴多的時(shí)候還是免俗不了層層的.then:

axios.get('xxx/xxx').then(res=>{
  return x
}).then(res=>{
  return xx
}).then(res=>{
  .......//不斷的嵌套
})

而ES2017新增async語(yǔ)法,就很好的優(yōu)化了這一點(diǎn):
比如在沒有使用async語(yǔ)法的時(shí)候雹熬,我們寫的異步函數(shù)是這樣的:

export function readMsg(from){
  return (dispatch,getState)=>{
    axios.post('/user/readmsg',{from}).then(res=>{
      const userid = getState().user._id
      if (res.status == 200 && res.data.code == 0) {
        dispatch(messageRead(from,userid,res.data.num))
      }
    })
  }
}

我們換成async語(yǔ)法對(duì)比看看:

export function readMsg(from){
  return async (dispatch,getState)=>{
    const res = await axios.post('/user/readmsg',{from})
    const userid = getState().user._id
    if (res.status == 200 && res.data.code == 0) {
      dispatch(messageRead(from,userid,res.data.num))
    }
  }
}

這樣一對(duì)比宽菜,看似修改的地方并不多,但是竿报,實(shí)際上用的就是一種同步的書寫方式铅乡,我們能看到,這種方式烈菌,隱式的執(zhí)行了異步操作阵幸,使用await來(lái)做異步的等待,這樣芽世,無(wú)論你有幾個(gè)互相依賴的異步要依次執(zhí)行侨嘀,都可以寫的簡(jiǎn)單易懂:

const res = await axios.post('/user/readmsg',{from})
const res1 = await axios.post('/user/xxxxx')
const res2 = await axios.post('/user/yyyyy')
console.log(res,res1,res2)//會(huì)等到所有的異步都執(zhí)行完再執(zhí)行

值得注意的是,asyncawait必須要一起使用捂襟。

有了這么方便的語(yǔ)法咬腕,以后的異步函數(shù),我覺得可以盡可能的用它來(lái)實(shí)現(xiàn)葬荷。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末涨共,一起剝皮案震驚了整個(gè)濱河市纽帖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌举反,老刑警劉巖懊直,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異火鼻,居然都是意外死亡室囊,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門魁索,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)融撞,“玉大人,你說(shuō)我怎么就攤上這事粗蔚〕①耍” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵鹏控,是天一觀的道長(zhǎng)致扯。 經(jīng)常有香客問我,道長(zhǎng)当辐,這世上最難降的妖魔是什么抖僵? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮缘揪,結(jié)果婚禮上裆针,老公的妹妹穿的比我還像新娘。我一直安慰自己寺晌,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布澡刹。 她就那樣靜靜地躺著呻征,像睡著了一般。 火紅的嫁衣襯著肌膚如雪罢浇。 梳的紋絲不亂的頭發(fā)上陆赋,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音嚷闭,去河邊找鬼攒岛。 笑死,一個(gè)胖子當(dāng)著我的面吹牛胞锰,可吹牛的內(nèi)容都是我干的灾锯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼嗅榕,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼顺饮!你這毒婦竟也來(lái)了吵聪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤兼雄,失蹤者是張志新(化名)和其女友劉穎吟逝,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體赦肋,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡块攒,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了佃乘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片囱井。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖恕稠,靈堂內(nèi)的尸體忽然破棺而出琅绅,到底是詐尸還是另有隱情,我是刑警寧澤鹅巍,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布千扶,位于F島的核電站,受9級(jí)特大地震影響骆捧,放射性物質(zhì)發(fā)生泄漏澎羞。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一敛苇、第九天 我趴在偏房一處隱蔽的房頂上張望妆绞。 院中可真熱鬧,春花似錦枫攀、人聲如沸括饶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)图焰。三九已至,卻和暖如春蹦掐,著一層夾襖步出監(jiān)牢的瞬間技羔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工卧抗, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留藤滥,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓社裆,卻偏偏與公主長(zhǎng)得像拙绊,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 異步編程對(duì)JavaScript語(yǔ)言太重要时呀。Javascript語(yǔ)言的執(zhí)行環(huán)境是“單線程”的张漂,如果沒有異步編程,根本...
    呼呼哥閱讀 7,311評(píng)論 5 22
  • 1 什么是異步編程 通過學(xué)習(xí)相關(guān)概念谨娜,我們逐步解釋異步編程是什么航攒。 1.1 阻塞 程序未得到所需計(jì)算資源時(shí)被掛起的...
    hugoren閱讀 2,656評(píng)論 2 10
  • async 函數(shù) 含義 ES2017 標(biāo)準(zhǔn)引入了 async 函數(shù),使得異步操作變得更加方便趴梢。 async 函數(shù)是...
    huilegezai閱讀 1,259評(píng)論 0 6
  • 一.非阻塞和異步 借用知乎用戶嚴(yán)肅的回答在此總結(jié)下漠畜,同步和異步是針對(duì)消息通信機(jī)制,同步代表一個(gè)client發(fā)出一個(gè)...
    Daniel_adu閱讀 1,825評(píng)論 0 8
  • 今天做得比較成功的幾件事坞靶, 第一憔狞,去房間看了裝修,總體感覺很好彰阴。執(zhí)行力瘾敢! 第二,處理工單尿这,以及一些雜事簇抵,近期自己的...
    王浩_4871閱讀 169評(píng)論 0 0