为什么这个javascript返回undefined?

时间:2012-05-16 09:07:14

标签: javascript loops javascript-events for-loop settimeout

var linksList = [
   "http://a.com",
   "http://b.com",
   "http://c.com",
]

for (var i=0; i<linksList.length; i++) {
    setTimeout(function() {
        console.log(linksList[i]); 
    }, 3000);
}  

我将它粘贴到chrome检查器中,它返回一个数字,无论出于何种原因(它似乎是一个完全随机的数字?)...然后它等待...然后返回3'未定义'控制台错误< / p>

1 个答案:

答案 0 :(得分:5)

使用闭包:

for (var i=0; i<linksList.length; i++) {
    (function(i){
       setTimeout(function() {
          console.log(linksList[i]); 
       }, 3000);
    })(i);
}

您的问题是,当setTimeout的回调被调用时,i = linksList.length已经,所以您输出:

 console.log(linksList[ linksList.length ]); 

3次,其中linksList[ linksList.length ]undefined