这是我的基本node.js应用程序,只有两个文件:
app.js
var express = require('express')
, routes = require('./routes')
, http = require('http')
, path = require('path');
var app = express();
module.exports = {
test: "test"
};
// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
// defining middlewares
app.get('/', routes.index);
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});
Run Code Online (Sandbox Code Playgroud)
和我的index.js:
var server = require('../app');
exports.index = function(req, res){
console.log(server);
res.send('Hello world');
};
Run Code Online (Sandbox Code Playgroud)
我的问题是当我去http:\\localhost:3000,我在我的控制台中看到{}而不是{test: "test"},它看起来 module.eports不能正常工作.为什么?
index.js从内部要求app.js,然后app.js从内部要求index.js,看起来像代码闻到我.此外,如果您使用,var app = module.exports = express()那么Express可以将您的应用视为中间件(例如,您可以拥有第一个应用程序的第二个应用requires程序,并将一些请求传递给它.
当我需要访问app另一个必需文件时,我执行以下操作:
// ./routes/index.js
module.exports = function(app){
var routes = {};
routes.index = function(req, res){
console.log(app.myConfig);
res.send('Hello world');
};
return routes;
};
// ./app.js
var app = module.exports = express();
app.myConfig = {foo:'bar'};
var routes = require('./routes/index.js')(app);
Run Code Online (Sandbox Code Playgroud)