JavaScript 回調(diào)函數(shù)

什么是回調(diào)函數(shù)艇抠?

回調(diào)函數(shù)是一個(gè)函數(shù)妒御,將會(huì)在另一個(gè)函數(shù)完成執(zhí)行后立即執(zhí)行樟氢「园恚回調(diào)函數(shù)是一個(gè)作為參數(shù)傳給另一個(gè)函數(shù)的函數(shù)。這個(gè)回調(diào)函數(shù)會(huì)在傳給的函數(shù)內(nèi)部執(zhí)行埠啃。

為什么我們需要回調(diào)死宣?

客戶端 JavaScript?在瀏覽器中運(yùn)行,并且瀏覽器的主進(jìn)程是單線程事件循環(huán)碴开。如果我們嘗試在單線程事件循環(huán)中執(zhí)行長(zhǎng)時(shí)間運(yùn)行的操作毅该,則會(huì)阻止該過程。從技術(shù)上講這是不好的潦牛,因?yàn)檫^程在等待操作完成時(shí)會(huì)停止處理其他事件眶掌。

在上面的代碼片段中,首先執(zhí)行g(shù)etMessage()函數(shù)巴碗,然后執(zhí)行displayMessage()朴爬。兩者都在瀏覽器的控制臺(tái)窗口中顯示了一條消息,并且都立即執(zhí)行橡淆。

在某些情況下召噩,一些代碼不會(huì)立即執(zhí)行。例如逸爵,如果我們假設(shè)getMessage()函數(shù)執(zhí)行 API 調(diào)用具滴,則必須將請(qǐng)求發(fā)送到服務(wù)器并等待響應(yīng)。這時(shí)我們應(yīng)該如何處理呢师倔?

如何使用回調(diào)函數(shù)抵蚊?

為了使用回調(diào)函數(shù),我們需要執(zhí)行某種無(wú)法立即顯示結(jié)果的任務(wù)溯革。為了模擬這種行為贞绳,我們用 JavaScript 的setTimeout()函數(shù)。該函數(shù)會(huì)暫停兩秒鐘致稀,然后在控制臺(tái)窗口中顯示消息“ Hi冈闭,there”。

“顯示的消息”將被顯示在瀏覽器的控制臺(tái)窗口中抖单。在這種情況下萎攒,首先遇八,我們需要等待getMessage()函數(shù)。成功執(zhí)行此函數(shù)后耍休,再執(zhí)行displayMessage()函數(shù)刃永。

回調(diào)的工作方式

從上一個(gè)例子可以看到,在getMessage()函數(shù)中羊精,我們傳遞了兩個(gè)參數(shù)斯够。第一個(gè)參數(shù)是msg變量,該變量顯示在瀏覽器的控制臺(tái)窗口中喧锦,第二個(gè)參數(shù)是回調(diào)函數(shù)读规。

現(xiàn)在,你可能想知道為什么將回調(diào)函數(shù)作為參數(shù)進(jìn)行傳遞 —— 要實(shí)現(xiàn)回調(diào)函數(shù)燃少,我們必須將一個(gè)函數(shù)作為參數(shù)傳給另一個(gè)函數(shù)束亏。

在getMessage()完成任務(wù)后,我們將調(diào)用回調(diào)函數(shù)阵具。之后碍遍,當(dāng)調(diào)用getMessage()函數(shù)時(shí),將引用傳給displayMessage()函數(shù)阳液,該函數(shù)就是回調(diào)函數(shù)怕敬。

注意,當(dāng)調(diào)用getMessage()函數(shù)時(shí)趁舀,我們僅將其引用傳給displayMessage()函數(shù)赖捌。這就是為什么你不會(huì)在它旁邊看到函數(shù)調(diào)用運(yùn)算符,也就是()符號(hào)矮烹。

Javascript 回調(diào)地獄

當(dāng)多個(gè)異步函數(shù)一個(gè)接一個(gè)地執(zhí)行時(shí)越庇,會(huì)產(chǎn)生回調(diào)地獄。它也被稱為厄運(yùn)金字塔奉狈。

如何避免回調(diào)地獄卤唉?

可以使用多種技術(shù)來(lái)避免回調(diào)地獄,如下所示仁期。

使用promise

借助 async-await

使用 async.js 庫(kù)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末桑驱,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子跛蛋,更是在濱河造成了極大的恐慌熬的,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赊级,死亡現(xiàn)場(chǎng)離奇詭異押框,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)理逊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門橡伞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)盒揉,“玉大人,你說我怎么就攤上這事兑徘「沼” “怎么了?”我有些...
    開封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵挂脑,是天一觀的道長(zhǎng)藕漱。 經(jīng)常有香客問我,道長(zhǎng)最域,這世上最難降的妖魔是什么谴分? 我笑而不...
    開封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任锈麸,我火速辦了婚禮镀脂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘忘伞。我一直安慰自己薄翅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開白布氓奈。 她就那樣靜靜地躺著翘魄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪舀奶。 梳的紋絲不亂的頭發(fā)上暑竟,一...
    開封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音育勺,去河邊找鬼但荤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛涧至,可吹牛的內(nèi)容都是我干的腹躁。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼南蓬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼纺非!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起赘方,我...
    開封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤烧颖,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后窄陡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體炕淮,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年泳梆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鳖悠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片榜掌。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖乘综,靈堂內(nèi)的尸體忽然破棺而出憎账,到底是詐尸還是另有隱情,我是刑警寧澤卡辰,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布胞皱,位于F島的核電站,受9級(jí)特大地震影響九妈,放射性物質(zhì)發(fā)生泄漏反砌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一萌朱、第九天 我趴在偏房一處隱蔽的房頂上張望宴树。 院中可真熱鬧,春花似錦晶疼、人聲如沸酒贬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)锭吨。三九已至,卻和暖如春寒匙,著一層夾襖步出監(jiān)牢的瞬間零如,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工锄弱, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留考蕾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓棵癣,卻偏偏與公主長(zhǎng)得像辕翰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子狈谊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348