我知道有很多类似于我的问题,但我找不到最佳解决方案。我正在使用 node 和 rethinkdb 创建一个 Web 应用程序。我想组织不同的 js 文件(模块),以便每个都有特定的任务。我有这个 query.js 文件,其查询结果必须传递给 routes.js 文件。我已经尝试通过以下方式实现这一点。
查询.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);
})
}
路由.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 文件访问的对象。