進行函數(shù)傳遞

2018-02-24 15:25 更新

舉例來說,你可以這樣做:

function say(word)  {
? console.log(word);
}

function execute(someFunction, value)  {
? someFunction(value);
}

execute(say,  "Hello");

請仔細閱讀這段代碼!在這里,我們把?say?函數(shù)作為_execute_函數(shù)的第一個變量進行了傳遞。這里傳遞的不是?say?的返回值,而是?say?本身!

這樣一來,?say?就變成了execute?中的本地變量?someFunction?,execute可以通過調用?someFunction()?(帶括號的形式)來使用?say?函數(shù)。

當然,因為?say?有一個變量,?execute?在調用?someFunction?時可以傳遞這樣一個變量。

我們可以,就像剛才那樣,用它的名字把一個函數(shù)作為變量傳遞。但是我們不一定要繞這個“先定義,再傳遞”的圈子,我們可以直接在另一個函數(shù)的括號中定義和傳遞這個函數(shù):

function execute(someFunction, value)  {
? someFunction(value);
}

execute(function(word){ console.log(word)  },  "Hello");

我們在?execute?接受第一個參數(shù)的地方直接定義了我們準備傳遞給?execute?的函數(shù)。

用這種方式,我們甚至不用給這個函數(shù)起名字,這也是為什么它被叫做?匿名函數(shù)

這是我們和我所認為的“進階”JavaScript的第一次親密接觸,不過我們還是得循序漸進?,F(xiàn)在,我們先接受這一點:在JavaScript中,一個函數(shù)可以作為另一個函數(shù)接收一個參數(shù)。我們可以先定義一個函數(shù),然后傳遞,也可以在傳遞參數(shù)的地方直接定義函數(shù)。

以上內容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號