闭包,简单概括为函数的嵌套,闭包的形成与变量的作用域以及变量的生存周期密切相关。
-
变量的作用域:
变量的作用域分为全局作用域和函数作用域,在函数内部定义变量是如果使用var关键字定义则该变量作用域为函数内部,否则为全局作用域。 -
变变量的生存周期:
全局变量的生存周期是永久的,除非我们手动清除,而对于函数内部所定义的局部变量在函数退出时就会自动销毁
闭包的作用:
- 封装变量
闭包可以把一些不需要暴露在全局的变量封装成“私有变量” - 延续局部变量的寿命
来两闭包的示例:
var func = function(){
var a = 1;
return function(){
a++;
alert( a );
}
}
var f = func();
f(); // 输出: 2
f(); // 输出: 3
f(); // 输出: 4
以上结构中,当执行var f = func();时,f返回了一个匿名函数的引用,它可以访问到func()被调用时的生产环境,而局部变量啊一直处在这个环境中。这里就形成了一个闭包的结构,局部变量的生命看起来被延续了。
<html>
<body>
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</body>
</html>
<script>
var nodes = document.getElementsByTagName('div');
for(var i=0; len=nodes.length; i<len; i++){
(function(){
nodes[i].onclick = function(){
console.log(i)
}
})(i);
}
</script>