舉例來說,你可以這樣做:
~~~
function say(word) {
? console.log(word);
}
function execute(someFunction, value) {
? someFunction(value);
}
execute(say, "Hello");
~~~
請仔細閱讀這段代碼!在這里,我們把?_say_?函數作為_execute_函數的第一個變量進行了傳遞。這里傳遞的不是?_say_?的返回值,而是?_say_?本身!
這樣一來,?_say_?就變成了_execute_?中的本地變量?_someFunction_?,execute可以通過調用?_someFunction()_?(帶括號的形式)來使用?_say_?函數。
當然,因為?_say_?有一個變量,?_execute_?在調用?_someFunction_?時可以傳遞這樣一個變量。
我們可以,就像剛才那樣,用它的名字把一個函數作為變量傳遞。但是我們不一定要繞這個“先定義,再傳遞”的圈子,我們可以直接在另一個函數的括號中定義和傳遞這個函數:
~~~
function execute(someFunction, value) {
? someFunction(value);
}
execute(function(word){ console.log(word) }, "Hello");
~~~
我們在?_execute_?接受第一個參數的地方直接定義了我們準備傳遞給?_execute_?的函數。
用這種方式,我們甚至不用給這個函數起名字,這也是為什么它被叫做?_匿名函數_。
這是我們和我所認為的“進階”JavaScript的第一次親密接觸,不過我們還是得循序漸進。現在,我們先接受這一點:在JavaScript中,一個函數可以作為另一個函數接收一個參數。我們可以先定義一個函數,然后傳遞,也可以在傳遞參數的地方直接定義函數。