[英]Javascript - continue foreach
我有一段代码:
var a = false;
function wait(milliseconds, async) {
if(!async) {
setTimeout(function() {
console.log('Sync timer done.');
a = true;
return true;
}, milliseconds*1000);
}
(...)
f_recipe.forEach(function(item, index) {
if (obj['actual_step'] != 0 && obj['actual_step'] != index ) {
e = "Desync";
throw e;
};
console.log("Step: " + obj.actual_step);
if(item.substr(item.length - 6) != "false)"){
if (eval(item)) {
obj['actual_step']++;
}
} else {
eval(item);
var ival = setInterval(function(){
if(a) {
console.log('do the next thing');
clearInterval(ival);
}
}, 1000);
}
});
但是当我开始“做下一件事”(间隔完成)时,forEach 循环不会继续到数组的下一个元素。 'a' 在超时后设置为 true(在 JS 中是一种同步等待)。 f_recipes 是一个带有函数调用的字符串数组(例如'wait(20, false)')。
如何让它工作?
您尝试做的事情似乎是一个非常糟糕的主意,但Promise.delay
可以帮助解决这个问题(在这里使用 Bluebird 因为它提供了Promise.delay
和Promise.each
):
function wait(seconds, dontActuallyWait) { return dontActuallyWait ? null : Promise.delay(seconds * 1000); } function runSequence(things) { return Promise.each(things, function(thing) { return eval(thing); }); } runSequence([ 'console.log("hello")', 'wait(2, false)', 'console.log("hello again")', 'wait(5, false)', 'console.log("goodbye")' ]);
<script src="https://cdnjs.cloudflare.com/ajax/libs/bluebird/3.5.1/bluebird.min.js"></script>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.