一个关于javascript匿名函数的问题分析
作者:
一个关于javascript匿名函数的问题分析,学习js的朋友可以参考下
匿名函数,就是没有名字的函数。如:
function (){
alert('a function');
}
但是,上面的代码会报错。firebug提示:function statement requires a name,也就是:函数必须要有个名字。
奇怪的是,如果我用一对()把这个没有名字的函数包起来,就不会报错了。如:
(function (){
alert('a function');
})
(注意包裹函数的()!).虽然这样不会报错,但谁能知道这个函数是否声明成功了呢?是不是因为根本没声明所以才不报错呢?我们这样来测试:让函数自己执行一次:
(function (){
alert('a function');
}())
可以看到,函数执行了,表明函数是存在的。
同样,如果这个时候去掉包裹函数的(),则依然会报前面那个错,函数也执行不了。。。
function (){
alert('a function');
}()
这对包裹函数的(),真有这么重要?哪位高手解释一下原理呢?
复制代码 代码如下:
function (){
alert('a function');
}
但是,上面的代码会报错。firebug提示:function statement requires a name,也就是:函数必须要有个名字。
奇怪的是,如果我用一对()把这个没有名字的函数包起来,就不会报错了。如:
复制代码 代码如下:
(function (){
alert('a function');
})
(注意包裹函数的()!).虽然这样不会报错,但谁能知道这个函数是否声明成功了呢?是不是因为根本没声明所以才不报错呢?我们这样来测试:让函数自己执行一次:
复制代码 代码如下:
(function (){
alert('a function');
}())
可以看到,函数执行了,表明函数是存在的。
同样,如果这个时候去掉包裹函数的(),则依然会报前面那个错,函数也执行不了。。。
复制代码 代码如下:
function (){
alert('a function');
}()
这对包裹函数的(),真有这么重要?哪位高手解释一下原理呢?
您可能感兴趣的文章:
- (转载)JavaScript中匿名函数,函数直接量和闭包
- Javascript的匿名函数讲解
- Javascript的匿名函数小结
- javascript 匿名函数的理解(透彻版)
- JavaScript 编写匿名函数的几种方法
- Javascript 匿名函数及其代码模式原理
- Javascript匿名函数的一种应用 代码封装
- 通过javascript的匿名函数来分析几段简单有趣的代码
- JavaScript 匿名函数(anonymous function)与闭包(closure)
- Javascript中的回调函数和匿名函数的回调示例介绍
- 详谈JavaScript 匿名函数及闭包
- JavaScript函数的一些注意要点小结及js匿名函数