JS中(function(){xxx})(); 这种写法是什么意思?

经常看到别人的JS脚本中有这样的写法:

(function(){
function a(){
   alert("a");
}
})();

这里的(function(){xxx})(); 是什么意思,为什么这么写,有什么好处?

阅读 109.6k
6 个回答

自执行匿名函数:

  • 常见格式:(function() { /* code */ })();
  • 解释:包围函数(function(){})的第一对括号向脚本返回未命名的函数,随后一对空括号立即执行返回的未命名函数,括号内为匿名函数的参数。
  • 作用:可以用它创建命名空间,只要把自己所有的代码都写在这个特殊的函数包装内,那么外部就不能访问,除非你允许(变量前加上window,这样该函数或变量就成为全局)。各JavaScript库的代码也基本是这种组织形式。

总结一下,执行函数的作用主要为 匿名自动执行,代码在被解释时就已经在运行了。

其他写法
(function () { /* code */ } ()); 
!function () { /* code */ } ();
~function () { /* code */ } ();
-function () { /* code */ } ();
+function () { /* code */ } ();

推荐阅读:立即调用的函数表达式

这个示例看起来不是那么的有用。用(function(){xxx})()是利用匿名函数和闭包用来执行xxx里面的代码,同时所有的定义比如变量的作用域都在闭包里,不会污染到外部命名空间。

1. 使这段代码被载入时候自动执行。
2. 避免污染全局变量。

因为js是函数作用域,所以如果想实现某个功能又不想污染全局变量的时候,会用这个自执行的匿名函数,常见于jquery插件

匿名自执行函数 也叫拉姆达函数, 这样的话相当于强行封装了一个块级作用域。因为es5没有块级作用域 所以这算是一个块级作用域的方法,参数可以在外面的括号里面传递

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏