在同一行呼叫匿名函數:為什麼它很重要
在閉包的上下文中,通常在同一行調用匿名函數正如它們所定義的。這種做法引發了有關底層機制及其背後原因的問題。
在 Javascript 中,可以使用三種方法定義函數。首先,Function 建構函式使用 new 關鍵字建立函數。其次,函數宣告使用 function 關鍵字和函數名稱。最後,函數表達式將函數指派給變數而不指定名稱。
在提供的程式碼中,使用函數表達式定義匿名函數:
(function(msg){alert(msg)})('SO');
但是,如果函數定義被刪除,程式碼失敗:
(function (msg){alert(msg)}) ('SO');
這是因為沒有分號,程式碼被解釋為兩個單獨的語句:
這在語義上不正確,因為函數之前未定義它被稱為。為了避免此錯誤,必須存在分號。
或者,可以如下定義和呼叫函數表達式:
var myFunc = function(msg){alert(msg);} myFunc('SO');
在這種情況下,函數被分配給變數在它被呼叫之前。然而,這種方法需要一個命名函數,這可能並不總是需要的。
在同一行呼叫匿名函數的做法允許立即執行函數,而不需要命名變數。當封裝只需要執行一次的程式碼時,這特別有用。此外,它還有助於防止命名衝突並減少程式碼庫中全域變數的數量。
若要進一步了解匿名函數和函數表達式,請參閱 ECMA 腳本規格(第 13 節函數定義)或其他資源,例如「jQuery 和 $ 問題」或上面程式碼片段中提供的範例。
以上是為什麼我們要在定義的同一行呼叫匿名 JavaScript 函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!