javascript中函數定義通常有兩種方法:
1. 普通的函數定義:
function f1 (){}
2. 變量式函數定義:
var f2 = function(){}
還有一種定義方法是new Function,由於這種方法並不常用,這里就不做解釋了。
那這兩種定義方法有什么不同呢?難道僅僅只是樣子不同而已嘛?當然不是這樣,我們來看個具體的例子吧,大家覺得以下代碼的執行結果是什么?
if (1 === 1) {
tellAlert();
} else{
function tellAlert(){
alert('hello');
}
}
執行結果是:會提示“hello”
那接下來這段代碼呢?
if (1 === 1) {
tellAlert();
} else{
var tellAlert = function (){
alert('hello');
}
}
執行結果是:游覽器不會提示“hello”,chrome中的控制台還會報錯:

從上例中,我們可以明顯看出,兩者很大的不同就是執行順序不同,這是function語句在解析時會發生被提升的情況。也就是說不管function被放置在哪里,它都會被移動到被定義時所在作用域的頂層。這樣的后果就是放寬了函數必須先聲明后使用的要求。
《javascript語言精粹》中推薦使用的方法是 var f1 = function()。這樣能明確表示f1 是一個包含一個函數值的變量。
而nodejs的源碼中,定義函數的方法是function f1()。
個人感覺,在控制自己的代碼邏輯的基礎上,直接用function f1()會更好點,代碼會更清楚點。
·
