NodeJs使用异步与循环下载
问题描述:
我有这个循环下载一些文件,它的工作正常。NodeJs使用异步与循环下载
但是这些文件是按照“2,3,4,1,5”顺序下载的,而不是“1,2,3,4,5”。
我知道怎么做。每个异步和瀑布异步,但我不知道如何做这个循环。
Config.TotalFiles = 5;
for(i = 1; i <= Config.TotalFiles; i++) {
$this.CreateJSONFile(i, function() {
cls();
});
}
当下载完成后我想打电话给我的回调,我已经试过这if(id == Config.TotalFiles)
,但它不工作,因为该ID是不好的。
我该如何做这个循环的“异步”过程?
感谢
答
您可以使用async.whilst此:
Config.TotalFiles = 5;
var count = 1;
//pass your maincallback that you want to call after downloading of all files is complete.
var callMe = function(mainCallback){
async.whilst(
function() { return count <= Config.TotalFiles; },
function(callback){
$this.CreateJSONFile(count, function() {
cls();
count++;
callback();
});
}, function(){
//This function is the final callback
mainCallback();
})
}
答
是的,你需要实现环异步。主要思想是在当前步骤完成后调用回调(如继续)。您可以使用上面提到的一些有用的库(async.js)。但你也必须明白,它不会并行完成(所以完成下载的时间将会增加)。
这些都是一些很好的例子,以帮助您:https://github.com/caolan/async/blob/v1.5.2/README.md#whilst
答
检查我的屏幕为请理解我的情况。
还是这个引擎收录https://pastebin.com/jtANeSxq
cls();
for(i = 1; i <= Config.TotalFolders; i++) {
$this.CreateJSONFile(i, function() {
setTimeout(function() {
cls();
}, 200);
});
}
CreateJSONFile(id, callback) {
console.log(chalk.hex("#607D8B")(`Creating JSON Files... [${id}/${Config.TotalFolders}]`));
var requestOptions = {
encoding: "binary",
method: "GET",
uri: `${Config.Url.Source}${Config.Url.Audio}` + `${id}/skeud.json`
};
request(requestOptions, function (error, response, body) {
if (!error && response.statusCode === 200) {
if(!fs.existsSync(Config.DownloadsPath + `${id}/skeud.json`)) {
fs.writeFile(Config.DownloadsPath + `${id}/skeud.json`, body, function(err) {
if(err) {
return console.log(err);
}
console.log(chalk.hex("#FFEB3B")(`JSON File ${chalk.inverse(id)} ${chalk.hex("#FFEB3B")("created")}`));
});
} else {
console.log(chalk.hex("#FFEB3B")(`JSON File ${chalk.inverse(id)} ${chalk.hex("#FFEB3B")("skipped")}`));
}
}
});
/*if(created == Config.TotalFolders) {
callback();
}*/
}
感谢
'async.times'? – Bergi
我总是有“1,5,3,4,2”...... – EyWN
这取决于每个'CreatJSONFile'调用的工作速度有多快。他们*始终以预期的顺序启动*。如果你想确保它们也按照预期的顺序结束,你唯一的选择是顺序执行而不是并行执行(使用'... Series'方法)。 – Bergi