Return 节点模块回调中的变量

Return Variable in Node Module Call Back

我正在使用 this NPM package 从访问数据库中获取 table 的 CSV 输出。

我的函数结构如下:

function createDB(mdbfile){
  var rawDB = mdb(mdbfile);
  var db = {}
  rawDB.tables(function(err, table){
    table.forEach(function(item){
      var rawTable = null;
      rawDB.toCSV(item, function(err, csv){
        rawTable = csv; //Doesn't work
      });
      console.log(rawTable); //Always null :(
      
      var newTable = Do stuff with CSV;
      db.item = newTable;
    });
  });

  return db
}

我确定这是一些范围界定问题,但我是节点的新手,不知道如何正确搜索它。据我所知,该模块是同步的,但作用域不起作用。

如有任何帮助,我们将不胜感激!不幸的是,我有一个客户必须使用访问数据库文件,而我只是想让它工作。

作用域看起来不错,但 toCsv 函数看起来不同步。您可以仔细检查源代码:https://github.com/maxogden/node-mdb/blob/master/index.js。因此,您将尝试在调用 toCsv 回调之前打印出 rawTable

我还会在两个回调中添加适当的错误处理,以查看您是否收到任何错误。

编辑:

由于您的 createDB 函数进行异步调用,因此它应该进行回调。下面的代码是一个可能适用于您的案例的示例。

// look into the async module, specifically forEach
const asyncForEach = require('async/forEach');

function createDB(mdbfile, next ){
  var rawDB = mdb(mdbfile);
  var db = {}
  rawDB.tables(function(err, table){

    if( err ) return next(err);     

    asyncForEach(
        table,
        function(item, cb){
            rawDB.toCSV(item, ( err, csv )=>{
                if( err ) return cb( err );
                // this processing can be done here or in the callback to asynForEach
                var newTable = Do stuff with CSV;
                db.item = newTable;
                cb(null, csv);
            };
        },
        function(err, csvs){
            // csvs can be processed and added to db here as well
            if ( err ) return next( err );
            return next( null, db );
        } );
   } );
}

然后您必须在调用 createDB 时提供回调:

createDB( mdbFile , ( err, db )=>{
    if( err ) return err;
    // use db e.g. res.send( db )
}

或者您可以研究如何使用 promises 来实现这一点。