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)
你们能告诉我一个线索吗?
最好的祝福
在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)
// 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)
当我创建连接(或连接池)并且只是希望我的模块能够访问数据库而无需创建另一个连接时,我会执行此操作。当然,一切都取决于您的项目,我的点击跟踪模块之一使用它自己的连接,所以我将数据库信息传递给它,然后它从那里做它自己的事情。这允许我有多个应用程序使用此跟踪器模块,同时每个应用程序连接到自己的数据库。
| 归档时间: |
|
| 查看次数: |
8800 次 |
| 最近记录: |