2025-02-09

 

   js中function對象是一個令人著迷的東西,但由於他太過於靈活,常常令人迷惑,下面我貼一些代碼

 

   大多數人這樣簡寫:

 

function test () {} 

《jsvascript語言精粹》整本書這樣寫:

 

var test = function () {} 

 

函數可以立即運行並賦值:

 

var test = function () {} () // test === undefined 

var test2 = function () {return '糖餅'}() // test2 === '糖餅' 

 

但是函數簡寫方式不能直接運行,下面代碼會報錯:

 

function test() {}() // SyntaxError: syntax error 

 

如果用”()“運行符包裹後正常:

 

(function test () {})(); 

 

其實這個 函數名test 已經沒有意義瞭,去掉就成瞭匿名函數,仍然可以自動執行函數體內代碼,常用的匿名函數寫法:

 

(function () {})(); 

 

匿名函數還可以這麼寫可能會”美觀“一點:

 

(function () {}());   

 

摘自 tmaic的專欄

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *