我正在使用PapaParse从我的JavaScript脚本中下载CSV文件,并且它运行良好。
但是,我有一个页面,我需要下载两个文件,然后才做一些工作,我想知道是否有更简洁的方法来做到这一点:
Papa.parse(url_seriesy, {
download: true,
header: true,
keepEmptyRows: false,
skipEmptyLines: true,
error: function(err, file, inputElem, reason) { // handle },
complete: function(y_results) {
Papa.parse(url_seriesx, {
download: true,
header: true,
keepEmptyRows: false,
skipEmptyLines: true,
error: function(err, file, inputElem, reason) { // handle },
complete: function(x_results) {
console.log(x_results.data);
}
});
}
});
这很有效,但非常笨拙。还有什么我可以做的吗?也许我可以使用承诺?
答案 0 :(得分:1)
如果我理解正确,您需要解析每个文件,然后在收集完所有结果后执行某些操作。有几种方法可以做到,但这是我可能做的一种方式(注意:我没有运行此代码;它可能需要调整):
var files = ["file1.csv", "file2.csv"];
var allResults = [];
for (var i = 0; i < files.length; i++)
{
Papa.parse(files[i], {
download: true,
header: true,
skipEmptyLines: true,
error: function(err, file, inputElem, reason) { /* handle*/ },
complete: function(results) {
allResults.push(results);
if (allResults.length == files.length)
{
// Do whatever you need to do
}
}
});
}