首页 存档 技术 查看内容

带你一分钟理解 JavaScript 闭包

2018-3-30 13:00 |来自: 互联网 282 0

摘要: JAVA知识知多少什么是闭包? 先看一段代码: function a(){ var n = 0; function inc() { n ; console.log(n); } inc(); inc(); }a(); //控制台输出1,再输出2 简单吧。再来看一段代码: function a(){ var n = 0; ...


JAVA知识知多少

什么是闭包?

先看一段代码:

function a(){    var n = 0;    function inc() {
n ; console.log(n);
}
inc();
inc();
}
a(); //控制台输出1,再输出2

简单吧。再来看一段代码:

function a(){    var n = 0;    this.inc = function () {
n ;
console.log(n);
};
}var c = new a();
c.inc(); //控制台输出1c.inc(); //控制台输出2

简单吧。

什么是闭包?这就是闭包!

有权访问另一个函数作用域内变量的函数都是闭包。这里 inc 函数访问了构造函数 a 里面的变量 n,所以形成了一个闭包。

再来看一段代码:

function a(){    var n = 0;    function inc(){
n ;
console.log(n);
} return inc;
}var c = a();
c(); //控制台输出1c(); //控制台输出2

看看是怎么执行的:

var c = couter(),这一句 couter()返回的是函数 inc,那这句等同于 var c = inc;

c(),这一句等同于 inc();注意,函数名只是一个标识(指向函数的指针),而()才是执行函数。

后面三句翻译过来就是:var c = inc; inc(); inc();,跟第一段代码有区别吗? 没有。

什么是闭包?这就是闭包!

所有的教科书教程上都喜欢用最后一段来说明闭包,但我觉得这将问题复杂化了。这里面返回的是函数名,没看过谭浩强C/C 程序设计的同学可能一下子没反应出带不带()的区别,也就是说这种写法自带一个陷阱。虽然这种写法更显高大上,但我还是喜欢将问题单一化,看看代码 1 和代码 2,你还会纠结函数的调用,你会纠结 n 的值吗?

为啥要这样写?

我们知道,js的每个函数都是一个个小黑屋,它可以获取外界信息,但是外界却无法直接看到里面的内容。将变量 n 放进小黑屋里,除了 inc 函数之外,没有其他办法能接触到变量 n,而且在函数 a 外定义同名的变量 n 也是互不影响的,这就是所谓的增强“封装性”。

而之所以要用 return 返回函数标识 inc,是因为在 a 函数外部无法直接调用 inc 函数,所以 return inc 与外部联系起来,代码 2 中的 this 也是将 inc 与外部联系起来而已。

常见的陷阱

看看这个:

function createFunctions(){    var result = new Array();    for (var i=0; i
声明:文章版权归原作者所有 部分文章转自互联网 如有侵权请联系 [邮箱地址] 删除

路过

雷人

握手

鲜花

鸡蛋

相关分类

返回顶部