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

标签 node.js express node-postgres

我是 Node.js 和 Express 的新手。

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

应用程序.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')));

路由/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();
      });
    });

我在浏览器中遇到错误:

Express 500 ReferenceError: pg is not defined

你们能给我一个线索吗?

最好的问候

最佳答案

在 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;
  ...
};

关于Node.js/Express - 如何在 routes/index.js 中获取 app.js 中定义的变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20842542/

相关文章:

Node.js + Passport : What happens to 3rd argument 'info' in done() method?

node.js - Mongoose CastError : Cast to undefined failed for value "[object Object]" at path "apps"

node.js - 使用 Mongoose-paginate 插件填充多个 Mongoose 模型字段

json - 将 json 解析为 Mongoose 架构

node.js - 使用 "node postgres"的 Nodejs 应用程序在 GKE 中每 60 分钟出现一次 "Connection terminated unexpectedly"

node.js - Sequelize ,将实体转换为普通对象

javascript - Mocha 6,巴别塔 7,ES6 : SyntaxError: Unexpected token export

MYSQL 通过 URL 选择

node.js - 无法安装 node-postgres

node.js - 如何优化 Postgresql max_connections 和 node-postgres 连接池?