Node.js导出问题

时间:2013-10-20 06:11:11

标签: javascript mysql module express require

我对NodeJS导出模块的方式感到好奇。我知道要导出一个方法,我们编写exports keyword.methodname。

但是,我的模块是一个连接:

//Require mysql connector that you installed with npm
var mysql      = require('mysql');

var conn_conf = {
    host     : 'localhost',
    port     : 3306,
    user     : 'root',
    password : 'root',
    database : 'nutrition_tracker'
}

var connection = mysql.createConnection(conn_conf);

connection.connect(function(err) {
    if(err) console.log("Could not connect to DB");
    else{
        console.log("Connected to "+conn_conf.database+' on '+conn_conf.host );

    }
});

然后在需要它的文件中:

var db2 = require('../db/mysql_conn');

console.log(db2)

但每次,db2都是{}。我无法理解为什么 - 我不应该要求模块给我连接吗?我甚至尝试在模块中返回连接,但同样的事情 - db2是{}。

1 个答案:

答案 0 :(得分:0)

在模块文件的末尾添加此行:

exports = module.exports = connection;

请注意,您的方法存在缺陷,因为您不知道require()调用返回的连接的状态是什么。您可以在打开连接之前发送查询。

更好的方法是导出工厂功能:

exports = module.exports = function(cb) {
   // your code as above
   // ...

   connection.connect(function(err) {
     if(err) {
       console.log("Could not connect to DB");
       cb(err);
     } else {
       console.log("Connected to "+conn_conf.database+' on '+conn_conf.host );
       cb(null, connection);
     }
   });
};

并以这种方式使用它:

var createDb = require('../db/mysql_conn');
createDb(function(err, db2) {
   console.log(db2);
});