关于javascript function对象那些迷惑分析_js面向对象

WBOY
Lepaskan: 2016-05-16 18:00:19
asal
959 orang telah melayarinya

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语言的哥么见过匿名函数后立即石化了…
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan