溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

js回調(diào)的案例分析

發(fā)布時(shí)間:2020-10-28 10:40:05 來源:億速云 閱讀:145 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(guān)js回調(diào)的案例分析的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。

在Javascript中,函數(shù)是第一類對(duì)象,這意味著函數(shù)可以像對(duì)象一樣按照第一類管理被使用。既然函數(shù)實(shí)際上是對(duì)象:它們能被“存儲(chǔ)”在變量中,能作為函數(shù)參數(shù)被傳遞,能在函數(shù)中被創(chuàng)建,能從函數(shù)中返回。因?yàn)楹瘮?shù)是第一類對(duì)象,我們可以在Javascript使用回調(diào)函數(shù)。下面我們一起了解一下回調(diào)。

簡單地講:回調(diào)是指在另一個(gè)函數(shù)執(zhí)行完成之后被調(diào)用的函數(shù)

稍復(fù)雜地講: 在 JavaScript 中,函數(shù)也是對(duì)象。因此,函數(shù)可以傳入函數(shù)作為參數(shù),也可以被其他函數(shù)返回。這樣的函數(shù)稱為高階函數(shù)。被作為參數(shù)傳入的函數(shù)就叫做回調(diào)函數(shù)。

下面說說為什么我們需要回調(diào)?

有一個(gè)非常重要的原因——JavaScript是事件驅(qū)動(dòng)的語言。這意味著,JavaScript不會(huì)因?yàn)橐却粋€(gè)響應(yīng)而停止當(dāng)前運(yùn)行,而是在監(jiān)聽其他事件時(shí)繼續(xù)執(zhí)行。

來看一個(gè)基本的例子:

function first(){
  console.log(1);
}
function second(){
  console.log(2);
}
first();
second();

正如你所料,first 函數(shù)首先被執(zhí)行,隨后 second 被執(zhí)行 —— 控制臺(tái)輸出下面內(nèi)容:

// 1
// 2

但如果函數(shù) first 包含某種不能立即執(zhí)行的代碼會(huì)如何呢?

例如我們必須發(fā)送請(qǐng)求然后等待響應(yīng)的 API 請(qǐng)求?為了模擬這種狀況,我們將使用 setTimeout,它是一個(gè)在一段時(shí)間之后調(diào)用函數(shù)的 JavaScript 函數(shù)。我們將函數(shù)延遲 500 毫秒來模擬一個(gè) API 請(qǐng)求,新代碼長這樣:

function first(){
// 模擬代碼延遲
  setTimeout( function(){
console.log(1);
  }, 500 );
}
function second(){
  console.log(2);
}
first();
second();

現(xiàn)在理解 setTimeout() 是如何工作的并不重要,重要的是你看到了我們已經(jīng)把 console.log(1); 移動(dòng)到了 500 秒延遲函數(shù)內(nèi)部。那么現(xiàn)在調(diào)用函數(shù)會(huì)發(fā)生什么呢?

first();
second();
// 2
// 1

即使我們首先調(diào)用了 first() 函數(shù),我們記錄的輸出結(jié)果卻在 second() 函數(shù)之后。

這不是 JavaScript 沒有按照我們想要的順序執(zhí)行函數(shù)的問題,而是 JavaScript 在繼續(xù)向下執(zhí)行 second() 之前沒有等待 first() 響應(yīng)的問題。

所以為什么給你看這個(gè)?

因?yàn)槟悴荒芤粋€(gè)接一個(gè)地調(diào)用函數(shù)并希望它們按照正確的順序執(zhí)行。

回調(diào)正是確保一段代碼執(zhí)行完畢之后再執(zhí)行另一段代碼的方式。

感謝各位的閱讀!關(guān)于js回調(diào)的案例分析就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI