如何在包含异步函数的循环之后完成任务

时间:2015-02-06 17:10:30

标签: javascript loops csv asynchronous d3.js

我是javascript的新手,但我还没找到问题的答案。

实际上我使用for循环来获取几个csv文件的内容,并将每个内容添加到全局csvstring,以便在最后下载总的csv文件。但是每个csv的内容是用d3.csv获得的,这是异步的,所以如果我在d3.csv中更新我的总csvstring,我不能用它来保存总csv,因为csvstring还没有更新。我该怎么做?

我的代码无效,如下:

//here is code to define the queries
csvstring = "";
for (i=0 ; i<queries.length ; ++i) {
  d3.csv(queries[i], function(data) {
    //here is code to format data as a csvstring and then
    csvstring += data_as_csvstring;
   }
});
//here is code to download csvstring as a csvfile

我希望自己清楚明白,并且事先感谢你的回答!

马格

1 个答案:

答案 0 :(得分:1)

你可以做一些递归并等到你在最后一次查询时做某事吗?

var getCsv = function(queries, csvstring, startAt, callback){
        d3.csv(queries[startAt], function(data) {
            csvstring += data_as_csvstring;
            if(index == queries.length){
                callback(csvstring);
            } else {
                getCsv(queries, csvstring, startAt++, callback);
            }
        });
    }

getCsv(queries, '', 0, function(csvstring){
        console.log(csvstring); //the complete string
    });