您的位置:首页 > 其它

6. 闭包浅谈

2015-11-11 10:26 363 查看
闭包:外部作用域访问内部作用域中变量的方法叫做闭包

1. 可以看成是for循环先执行,第一个function中 i 是10.

// 这段代码输出的是10个10而不是期望的0到9,因为闭包内是对i的引用,然后函数执行时i已经变成了10
function f1() {
for (var i = 0; i < 10; i++) {
setTimeout(function() {
console.log(i)
}, 1000);
}
}
f1();


2. 第二个function中e 有 i的拷贝(1到10的拷贝)

// 解决以上的问题可以采用自执行的匿名函数
function f2() {
for (var i = 0; i < 10; i++) {
(function(e) {
setTimeout(function() {
console.log(e);
}, 1000);
})(i);
}
}
f2();
// 这里的匿名函数将i作为参数,这里的e会有i的一个拷贝,而引用时是对e的引用,这就避免了上述的问题


3. 闭包的2种常见写法

// 写法一:
var li = document.getElementsByTagName('li');
for (var i = 0; i < li.length; i++) {
li[i].onclick = (function(n){
// 内部的函数被绑定到事件上了( 父函数运行,然后把里面的函数返回了,然后返回给绑定的事件上 );
return function(){
alert(n);
}
})(i);
}


// 写法二:
var li = document.getElementsByTagName('li');
for (var i = 0; i < li.length; i++) {
(function(n){
li[i].onclick = function(){
alert(n);
}
})(i);
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: