Node.js/Express - 如何在routes/index.js中的app.js中定义变量?

And*_*dré 5 node.js express node-postgres

我是Node.js和Express的新手.

如何在"routes/index.js"中访问名为"pg"的"app.js"中创建的变量?

app.js

/**
 * Module dependencies.
 */

var express = require('express');
var routes = require('./routes');
var user = require('./routes/user');
var http = require('http');
var path = require('path');

var pg = require('pg');
var conString = "postgres://someuser:somepass@localhost/postgres"

var app = express();

// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
Run Code Online (Sandbox Code Playgroud)

路线/ index.js

/*
 * GET home page.
 */

exports.index = function(req, res){

    var client = new pg.Client(conString);
    client.connect(function(err) {
      if(err) {
        return console.error('could not connect to postgres', err);
      }
      client.query('SELECT NOW() AS "theTime"', function(err, result) {
        if(err) {
          return console.error('error running query', err);
        }
        console.log(result.rows[0].theTime);
        //output: Tue Jan 15 2013 19:12:47 GMT-600 (CST)
        client.end();
      });
    });
Run Code Online (Sandbox Code Playgroud)

我在浏览器中收到错误:

Express 500 ReferenceError: pg is not defined
Run Code Online (Sandbox Code Playgroud)

你们能告诉我一个线索吗?

最好的祝福

rob*_*lep 7

在Express中将任何东西传递给路由处理程序(无论它们是否在不同的文件中声明)的简单方法是使用app.locals:

// app.js
...
var app = express();
...
app.locals.someVar = someValue;
...

// somewhere else
module.exports.myhandler = function(req, res) {
  var someVar = req.app.locals.someVar;
  ...
};
Run Code Online (Sandbox Code Playgroud)


Chr*_*ris 3

// app.js
var routes = require('./routes/index')({ varname: thevar });
...
...
Run Code Online (Sandbox Code Playgroud)

// /routes/index.js
module.exports = function(options) {
    var moduleVar = options.varname;

    return {
        someMethod: function (req, res) { var i = moduleVar + 2; // etc},
        anotherMethod: function (req, res) {}
    };
};
Run Code Online (Sandbox Code Playgroud)

当我创建连接(或连接池)并且只是希望我的模块能够访问数据库而无需创建另一个连接时,我会执行此操作。当然,一切都取决于您的项目,我的点击跟踪模块之一使用它自己的连接,所以我将数据库信息传递给它,然后它从那里做它自己的事情。这允许我有多个应用程序使用此跟踪器模块,同时每个应用程序连接到自己的数据库。