作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我运行这段代码时:`
for (var start = 1; start < 10; start++) {
setTimeout(function () {
alert('hello');
}, 3000 * start);
}
alert('Finish');
为什么 for 循环没有完成,但代码 'alert('Finish')' 仍在运行。如何使 alert('Finish')
在完成 for 循环后运行。谢谢。
最佳答案
从技术上讲,这就是它已经在做的事情。
循环运行(设置超时),然后触发“完成”警报。我猜你想要的是在所有超时都触发后触发的“完成”。执行此操作的简单方法可能是将完成添加到它自己的超时(因此它会在该时间后运行)。
类似的东西:
for (var start = 1; start < 10; start++){
setTimeout(function () { console.log('hello'); }
, 10 * start);};
// use final "start" time to set last timeout to fire off its event, after all other timeouts have run
setTimeout(function () {
console.log('Finish');
}, 10 * (start+1));
注意:我更改了时间并使用了控制台日志,因此它运行得更快以进行测试。
关于javascript - 如何在 for 循环后运行此代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21932233/
我是一名优秀的程序员,十分优秀!