JavaScript 中的匿名函数((function() {})();)与变量的作用域

Posted 河图书卦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript 中的匿名函数((function() {})();)与变量的作用域相关的知识,希望对你有一定的参考价值。

以前都是直接用前端框架Bootstrap,突然想看看javascript,发现javascript是个非常有趣的东西,这里把刚碰到的一个小问题的理解做下笔录(废话不多说,上代码)。

/**
 * Example 1
 */
var localvar = "local var";
console.log(localvar);//local var

/**
 * Example 2
 */
console.log(x === undefined); // true
var x = 3;

/**
 * Example 3
 */
var myvar = "my value";
//Test01
//will return a value of undefined
(function() {
  console.log(myvar); // undefined
  var myvar = "local value";
  console.log(myvar); // local value
})();
console.log(myvar);//my value
//Test02
(function myFunction(){
  console.log(myvar);//my value
})();
//Test03
var test = new function(){
  console.log(myvar);//my value
};

解释如下:

(1).JavaScript 变量的特别之处是,你可以引用稍后声明的变量而不会引发异常。这一概念称为变量声明提升(hoisting);

(2).JavaScript 变量感觉上是被“提升”或移到了函数或语句的顶部。然而提升后的变量将返回 undefined 值。

(3).在使用或引用某个变量之后进行声明和初始化操作,这个被提升的引用仍将得到 undefined 值。

(4).这里Example 3中Test01是这次问题的关键,Test01和Test02是很相似的(至少我看着很相似)。但是最后输出结果不能用(1)、(2)、(3)来解释

  经过查看官方API文档发现,在匿名函数(function() {})();的使用中形成了闭包(重点,不清楚的可以查阅闭包的概念,闭包概念还是好理解的);

  由于闭包的存在,全局变量自然无法访问(闭包的一个重要原因就是为了避免访问全局变量),故Test01 function中第一句输出结果为undefined

总结原因:匿名函数(function() {})();是一个特殊的闭包写法。


以上是关于JavaScript 中的匿名函数((function() {})();)与变量的作用域的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript中的匿名函数及函数的闭包

JavaScript中的匿名函数及函数的闭包(转)

Javascript中的回调函数和匿名函数的回调

深入理解JavaScript中的函数操作

JavaScript中的闭包与匿名函数

eslint 或 jslint 中的 Javascript lambda/匿名函数长度警告