为了账号安全,请及时绑定邮箱和手机立即绑定

js闭包在循环语句中的一个问题

js闭包在循环语句中的一个问题

拉莫斯之舞 2019-04-10 20:48:58
window.onload=function(){varlis=document.getElementsByTagName('li');varlen=lis.length;for(vari=0;i
查看完整描述

2 回答

?
ABOUTYOU

TA贡献1812条经验 获得超5个赞

这里有这个for循环案例的详解:[JS进阶]闭包,作用域链,垃圾回收,内存泄露
实例2:给每个li添加点击事件
varoli=document.getElementsByTagName('li');
vari;
for(i=0;i<5;i++){
oli[i].onclick=function(){
alert(i);
}
}
console.log(i);//5
//执行匿名函数
(function(){
alert(i);//5
}());
上面是一个经典的例子,我们都知道执行结果是都弹出5,也知道可以用闭包解决这个问题,但是我刚开始始终不能明白为什么每次弹出都是5,为什么闭包可以解决这问题。后来捋一捋还是把它弄清晰了:
a.先来分析没用闭包前的情况:for循环中,我们给每个li点击事件绑定了一个匿名函数,匿名函数中返回了变量i的值,当循环结束后,变量i的值变为5,此时我们再去点击每个li,也就是执行相应的匿名函数(看上面的代码),这是变量i已经是5了,所以每个点击弹出5.因为这里返回的每个匿名函数都是引用了同一个变量i,如果我们新建一个变量保存循环执行时当前的i的值,然后再让匿名函数应用这个变量,最后再返回这个匿名函数,这样就可以达到我们的目的了,这就是运用闭包来实现的!
b.再来分析下运用闭包时的情况:
varoli=document.getElementsByTagName('li');
vari;
for(i=0;i<5;i++){
oli[i].onclick=(function(num){
vara=num;//为了说明问题
returnfunction(){
alert(a);
}
})(i)
}
console.log(i);//5
这里for循环执行时,给点击事件绑定的匿名函数传递i后立即执行返回一个内部的匿名函数,因为参数是按值传递的,所以此时形参num保存的就是当前i的值,然后赋值给局部变量a,然后这个内部的匿名函数一直保存着a的引用,也就是一直保存着当前i的值。所以循环执行完毕后点击每个li,返回的匿名函数执行弹出各自保存的a的引用的值。
                            
查看完整回答
反对 回复 2019-04-10
?
蝴蝶刀刀

TA贡献1801条经验 获得超8个赞

简单来说:利用闭包的特性把每一个i的值都存储在内存中。因为当点击时for循环已经结束,所以会弹出最后一个i的值。
详细可以看看:详解js闭包
                            
查看完整回答
反对 回复 2019-04-10
  • 2 回答
  • 0 关注
  • 467 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信