闭包,定时器,循环

Posted 王汉炎

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了闭包,定时器,循环相关的知识,希望对你有一定的参考价值。

1.对于一个一般的循环,顺序输出01234

for(var i=0;i<5;i++){
console.log(i)
}

2.如果加上定时器,实现每隔两秒出现一个数字

for(var i=0;i<5;i++){
    setTimeout(function(){
        console.log(i);//5个4
    },2000)
}

你会发现出现了5个4,并且还是一起出的,原因是定时器是异步函数,外部函数执行的很快,等执行定时器时for循环已经执行完毕,i等于4,我们可以这样改

for(var i=0;i<5;i++){
(function(){
 setTimeout(function(x){
        console.log(x);//01234
    },2000)
})(i)
}

你又会发现,现在是出现01234,但是感觉定时器没起作用,两秒后01234一起出现,我们可以这样改

for(var i=0;i<5;i++){
(function(){
 setTimeout(function(x){
        console.log(x);//01234
    },x*2000)
})(i)
}

这样你就会发现效果实现了,每隔两秒出现一个数字

以上是关于闭包,定时器,循环的主要内容,如果未能解决你的问题,请参考以下文章

闭包,定时器,循环

前端(十三)—— JavaScript高级:回调函数闭包循环绑定面向对象定时器

几行代码简单来看闭包

经典闭包

[TimLinux] JavaScript 中循环执行和定时执行

JavaScript闭包应用场合——控制前端接口轮训