Javascript 使用wait new Promise()时,for循环后的代码未执行
我有一个异步函数,有一个循环:Javascript 使用wait new Promise()时,for循环后的代码未执行,javascript,for-loop,async-await,Javascript,For Loop,Async Await,我有一个异步函数,有一个循环: let z; let step = 100; for(z=0; z < (combinedData.length-1)/step; z += 1){ // FURTHER CODE } 除了没有显示“结束”,一切都是对的。 我检查过了,没有错误 //LONG CODE TO EXECUTE NOT PASTING BECAUSE IRRELEVANT 所以不用担心 我认为,这一错误就在于 if(!(i<a.length))return;
let z;
let step = 100;
for(z=0; z < (combinedData.length-1)/step; z += 1){
// FURTHER CODE
}
除了没有显示“结束”,一切都是对的。
我检查过了,没有错误
//LONG CODE TO EXECUTE NOT PASTING BECAUSE IRRELEVANT
所以不用担心
我认为,这一错误就在于
if(!(i<a.length))return;
if(!(i这可以让您了解如何正确编码循环:
async function delayedFunc(i, index) {
await new Promise(resolve => setTimeout(resolve, 100));
console.log(i, index);
}
async function main(array) {
for (const [index, item] of array.entries()) {
await delayedFunc(item, index);
}
console.log('Done!');
}
main([1, 2, 3, 4, 5]);
循环后的代码不会执行,因为您不会解析或拒绝创建的承诺
你说得对,这个if(!(I)我如何在不使用数组的情况下获取项的索引。indexOf(item)
?有没有办法?@SkillGG我更新代码以显示索引。你可以在其他类型的循环中对其进行编码。我只想展示如何使用async/await来实现你的目标。
if(!(i<a.length))return;
async function delayedFunc(i, index) {
await new Promise(resolve => setTimeout(resolve, 100));
console.log(i, index);
}
async function main(array) {
for (const [index, item] of array.entries()) {
await delayedFunc(item, index);
}
console.log('Done!');
}
main([1, 2, 3, 4, 5]);
if(!(i<a.length)){
return rs(); // Returns and resolves your created promise
}