您的位置:首页 > Web前端 > JavaScript

JavaScript中的闭包

2016-07-28 10:10 127 查看
闭包,是ECMAScript中一个非常重要的概念。我在“ JS中的作用域链(scope
chain)”这篇博文中已经详细阐述了关于作用域链的内容。其实,作用域链的问题就是从闭包引出来的,之所以先说作用域链,是因为我觉得如果把作用域链的概念搞清楚了,那么闭包理解起来就轻松多了。

一句话说啥是闭包:函数嵌套函数,内部函数引用了外部函数的局部变量,这样就形成了闭包。

几个重要的point:

·在后台执行环境中,闭包的作用域链包含着它自己的作用域、包含函数的作用域和全局作用域。

·通常,函数的作用域及其变量在函数执行完毕后被销毁。但是,如果该函数有闭包存在,那么这个函数的作用域将会一直保存到闭包消失为止。

·鉴于上一点,可以得知闭包会携带包含它的函数的作用域,因此会比其它函数占用更多的内存空间。故闭包要谨慎使用,使用完毕要注意回收空间。

使用闭包的典型场景:

·模仿块级作用域

这个可是挺有意思,不但解决了全局变量污染问题,还不用操心垃圾回收。撸一段代码如下:

function outFunction () {
var count = 10;

(function(){
for( var i=0; i<count; i++ ) {
alert(i);
}
})();

alert(i);	//然而并没有什么卵用。。你是访问不到i的
}
在外部函数outFunction里面创建了一个闭包,这个闭包是一个自执行函数,它可以通过作用域链找到外部变量count,并且执行完毕就自动滚蛋(自动销毁)。清清爽爽。

·利用闭包可以在对象中创建私有变量。

即使JavaScript中没有正式的私有对象属性的概念,但可以使用闭包来实现公有方法,通过公有方法去访问在包含作用域中定义的变量,那么这些包含作用域中的变量就变成私有对象属性咯。

结尾强插几句,画风和本文有差异。JavaScript没有接口继承和实现继承,所以撸出一条原型链。JavaScript中需要闭包的概念,又撸出一条作用域链。这两条链子威力无穷,是修炼内功心经大法。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript 闭包