Node.js函数作用域 - Azure表

问题描述 投票:0回答:1

所以我有这样的代码。

 var query = new storage.TableQuery().where('PartitionKey eq ?', req.body.RowKey._); 
storageClient.queryEntities(fieldtable, query, null, function (error, result, response) {


    var modelEntries = {};  
    var enumList = {};
    var enumName;
    modelEntries = result.entries;
    console.log(modelEntries);

    for (var i = 0; i < modelEntries.length; i++){

        if (result.entries[i].fielddatatype._ === "Enum"){
            enumName = result.entries[i].fieldname._;
            query = new storage.TableQuery().where('EnumName eq ?', enumName);

            storageClient.queryEntities(enumvalue, query, null, function (error, result, response) {
                enumList[enumName] = result.entries;
            });

        }

    }

    res.end(JSON.stringify(enumList));


});

我的问题在这里。

storageClient.queryEntities(enumvalue, query, null, function (error, result, response) {
      enumList[enumName] = result.entries;
});

EnumList在我调试时接收数据。但是一旦它超出了函数的范围,它就是空的。我认为这是一个功能范围问题,但我不太确定。

  • result.entries有结果。
  • fieldname也有数据,所以这两件事都不是问题。
node.js azure-table-storage
1个回答
1
投票

发生这种情况是因为queryEntities是一个异步函数,而res.end()在for循环结束之前执行。在这种情况下,我建议看看async module并使用async.eachOf(...)。它允许您针对“事物”列表运行异步调用,并在完成所有异步调用时为您提供运行函数的位置。

var async = require('async');

// ...

async.eachOf(modelEntries, function(value, key, next) {

    if (result.entries[key].fielddatatype._ === "Enum") {
        enumName = result.entries[key].fieldname._;
        query = new storage.TableQuery().where('EnumName eq ?', enumName);

        storageClient.queryEntities(enumvalue, query, null, function (error, result, response) {
            enumList[enumName] = result.entries;
            next();
        });     
    }

}, function(err) {

    res.end(JSON.stringify(enumList));

});
© www.soinside.com 2019 - 2024. All rights reserved.