
这两段代码为什么输出结果不一样,差别在哪?
第一个for(vari=0;i<5;i++){(function(i){setTimeout(function(){console.log(i);},i*1000);})...
第一个
for (var i = 0; i < 5; i++) {
(function(i) {
setTimeout(function() {
console.log(i);
}, i * 1000);
})(i);
}
第二个
for (var i = 0; i < 5; i++) {
(function() {
setTimeout(function() {
console.log(i);
}, i * 1000);
})(i);
} 展开
for (var i = 0; i < 5; i++) {
(function(i) {
setTimeout(function() {
console.log(i);
}, i * 1000);
})(i);
}
第二个
for (var i = 0; i < 5; i++) {
(function() {
setTimeout(function() {
console.log(i);
}, i * 1000);
})(i);
} 展开
展开全部
第一个function(i) 第二个function()
我记得以前看过js是又内向外取数据的,也就是说第一个用的i是function(i) 里的i,第二个用的i是for循环里的i。
你将for循环中的i换个变量名,输出的值就一样了。尽量避免变量名重复。
我记得以前看过js是又内向外取数据的,也就是说第一个用的i是function(i) 里的i,第二个用的i是for循环里的i。
你将for循环中的i换个变量名,输出的值就一样了。尽量避免变量名重复。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询