<span style="font-family:SimHei;font-size:14px;"> <script type="text/javascript">
for(var i=0;i<3;i++) {
setTimeout(function () {
console.log(i),100*i
})
}
</script></span>
本以为上述代码会输出0,1,2,可是它就输出3个3,但是下面这样写,它就会输出3个3:
<span style="font-family:SimHei;font-size:14px;"><script type="text/javascript">
for(var i=0;i<3;i++) {
setTimeout(
console.log(i),100+i
)
}</span>考虑了很长时间,才知道,for语句不会因为有setTimeout的存在而停止,他会跳过setTimeout,setTimeout设定的是100毫秒的延迟,而for语句执行根本用不了那么长时间,但是为什么把关键字function去掉就可以了,呵呵,我相信大家应该都有自己的想法了。
还是那个原则,我分享的东西不高大上,但是都是平时我们容易忽视,容易出错的地方,写出来与大家分享!
本文探讨了JavaScript中setTimeout函数的一个常见误区,即在循环中使用时如何避免因变量作用域问题导致的输出错误。通过对比不同写法,揭示了闭包在异步编程中的微妙之处。
375

被折叠的 条评论
为什么被折叠?



