JavaScript函数的多种定义方法

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 () {}());

看到这,刚接触js哥么是否要疯掉了?我曾看到我项目搞C语言的哥么见过匿名函数后立即石化了…

js function的写法确实变化莫测,以前看jquery插件经常会到这样的代码(function test () {})(),感觉很奇怪,前阵刚明白,这是自执行。