for循环中输出同一变量值

本文探讨了JavaScript中常见的循环结合setTimeout导致的变量污染问题,并提供了三种利用闭包解决问题的方法,包括通过参数传递、声明局部变量以及返回函数的方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


//循环输出通一变量值
for(var i=0;i<5;i++){  console.log(i)   //0,1,2,3,4  全局
   setTimeout(function(){
       console.log(i)                   //5,5,5,5,5  内部 
   },1000);
}

为什么会产生这样的结果?

首先,这里的i属于全部变量,即函数中所获取的i。

再者,i<5时,i一直在自加,知道i=5时停止自加,然后开始执行函数,所以目前函数中i已经为5。


使用闭包解决:

//方法一:i作为参数传递至内部函数  
for(var i=0;i<5;i++){
   (function(k){
    setTimeout(function(){console.log(k)},1000)
    })(i);
}
//方法二:闭包内声明局部变量K,将i赋值给K  
for(var i=0;i<5;i++){
   (function(){
    var K = i;
    setTimeout(function(){console.log(K)},1000)
    })();
}
//方法三:闭包内返回函数
for(var i=0;i<5;i++){
    (function(){
       return function(){console.log(i)}
     })()()
}
或for(var i=0;i<5;i++){
    setTimeout((function(k){
       return function(){console.log(k)}
     })(i),1000)
}或
for(var i=0;i<5;i++){
    (function(k){
       return function(){console.log(k)}
     })(i)()
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值