我知道有很多类似于我的问题,但我找不到最佳解决方案。 我正在创建一个带有node和rethinkdb的Web应用程序。我想组织不同的js文件(模块),以便每个文件都有特定的任务。 我有这个query.js文件,其查询结果必须传递给routes.js文件。 我尝试过以下方式实现这一点。
query.js
//dependencies
var express = require('express');
var path = require('path');
var r = require('rethinkdbdash')({
port: 28015,
host: 'localhost',
db: 'stocks'
});
var len;
//function to get companies list
exports.clist = function(){
r.table('company')
.run()
.then(function(response){
return response;
})
.error(function(err){
console.log(err);
})
}
console.log(exports.clist[0].id)
//function to get number of entries in database
exports.clen = function(){
r.table('company')
.run()
.then(function(response){
len = Object.keys(clist).length;
return len;
})
.error(function(err){
console.log(err);
})
}

routes.js
//dependencies
var express = require('express');
var request = require('request');
var path = require('path');
var r = require('rethinkdbdash')({
port: 28015,
host: 'localhost',
db: 'stocks'
});
//query module
var query = require('./query')
clist = query.clist();
clen = query.clen();
//create router object
var router = express.Router();
//export router
module.exports = router;
//home page
router.get('/', function(req, res) {
console.log('served homepage');
res.render('pages/home');
});
//--companies page--//
router.get('/company', function(req,res){
console.log('served companies page')
res.render('pages/company', {
clist: clist,
x:clen
});
});

query.js中的控制台日志显示无法读取未定义的属性id。
另外我想知道有没有办法直接传递变量而不是使用函数然后调用它。 如果解决方案很明显,我很抱歉。
总结一下,我希望可以从routes.js文件中访问作为对象的查询结果。
答案 0 :(得分:0)
注意:由于exports.clist1
是一种异步方法,您不能期望在下一行打印结果,因此请注释此行并按照以下方式进行操作
//console.log(exports.clist[0].id)
您必须注册一个中间件才能使其正常工作,否则,只有在快速服务器启动时才会调用查询,而不是每次请求都会调用。
所以你可以这样做,
希望你的启动文件(app.js)中有这样的东西,
var app = module.exports = express();
routes.js
//query module
var query = require('./query')
var app = require('../app'); // this should resolve to your app.js file said above
//clist = query.clist();
//clen = query.clen();
// middleware to populate clist & clen
app.use(function(req, res, next){
query.companyList(function(err, data){
if(!err) {
req.clist = data.clist;
req.clen= data.clen;
}
next();
});
});
query.companyList(function(err, data){
if(err) {
console.log(err);
} else {
console.log(data.clist[0].id);
console.dir(data.clist);
}
});
//create router object
var router = express.Router();
//export router
module.exports = router;
//home page
router.get('/', function(req, res) {
console.log('served homepage');
res.render('pages/home');
});
//--companies page--//
router.get('/company', function(req,res){
console.log('served companies page')
res.render('pages/company', {
clist: req.clist,
x: req.clen
});
});
像这样更改你的query.js,
//function to get companies list
exports.companyList = function(next){
r.table('company')
.run()
.then(function(response){
var list = {
clist: response,
clen: Object.keys(response).length
};
next(null, list);
})
.error(function(err){
console.log(err);
next(err);
})
};