使用async.series的回调填充数组

时间:2015-08-10 11:02:06

标签: javascript node.js

我的回调功能在' async.series'返回多个值并从'元素创建多个输出。

如何使用' forEach'将返回值写入数组?

async.series(
    {
        // Browse
        elements: function(callback) {
            Server_browse(item, function(result) {
                callback(null,result);
            });
        },
    },
    function(err,result) {
        if (err) {
            console.log(" error : ", err);
            console.log(err.stack);
        }

        console.log('elements=' + JSON.stringify(result.elements));
    }
);

2 个答案:

答案 0 :(得分:0)

如果您只提出一个请求,则无法使用caolan / async。

item变量来自Server_browse(item, ...

我可能错了,因为缺少信息,但我认为你想实现这个目标:

var items = ['query1', 'query2', 'query3'];

async.mapSeries(
    items,

    // for each item
    function(item, callback) {
        Server_browse(item, function(result) {
            callback(null, result.elements);
        });
    },

    // when all queries are done
    function(error, resultElements) {
        console.log(resultElements)
    }
);

答案 1 :(得分:0)

以下是其他功能'浏览'和Server_browse。

功能' Server_browse'将文件夹或变量委托给函数'浏览'。在'浏览'我将在一个数组中添加变量或调用' Server_browse'再次,如果Item是一个文件夹。目前,我将所有文件夹和变量分别放在' console.log(result.elements)'上。但我会写一个数组中的所有文件夹和变量。

var browse = function(item,indx,array,callback){
// 'item' is a Folder or Variable which i get from the server
//item = {"MyVariable1":{"referenceTypeId":"ns=0;i=46","isForward":true,"nodeId":"ns=1;i=1005","browseName":{"namespaceIndex":0,"name":"MyVariable1"},"displayName":{"text":"MyVariable1"},"nodeClass":"Variable","typeDefinition":"ns=0;i=63"}};



var child = ns='+item.browseName.namespaceIndex+';i='+item.nodeId.value;
  if (item.$nodeClass.key == 'Variable') {
        callback(item);
    }else{
        Server_browse(child,function(result){
            callback(result);
        });
    }
}
var Server_browse = function(item,callback){
        node_browse.session.browse( item,function (err, itemResults,diagnostics) {
            if (err) {
                console.log(err);
                console.log(itemResults);
                console.log(diagnostics);
            }else{
                for(var i=0; i<itemResults.length; i++){
                    itemResults[i].references.forEach(function(element,index,arr){
                        browse(element, index, arr, function(item){
                            callback(item);                             
                        });
                    });
                }
          }
    });
}