我试图从NodeJS中的RethinkDB中的文档中获取数据,并将结果传递给我希望在模板文件中使用的变量,但是当我尝试打印时,它总是undefined
data
变量#{data}
变量(我使用pug / jade),因为它是异步调用(我认为)。
'use strict';
var r = require('rethinkdb');
module.exports = function IndexModel() {
data: {
r.connect({host: '127.0.0.1', port: 28015}, function(err, conn) {
r.db('mydb').table('mytable').run(conn).then(function(cursor) {
cursor.toArray(function(err, result) {
if (err) throw err;
return JSON.stringify(result, null, 2);
});
});
});
}
};
我认为这一定是因为nodejs希望它成为一个对象,所以我试着像JSON.parse(JSON.stringify(result, null, 2))
那样解析它,但是会抛出相同的错误。
当我执行console.log(JSON.stringify(result, null, 2))
时,会在错误后打印 。
[
{
"id": "307ad5e9-a0db-461b-a564-081d73f9b34f",
"title": "hello"
}
]
如果需要,这是确切的错误:
Cannot read property 'length' of undefined
at eval (eval at wrap (C:\Users\Me\Project\node_modules\pug-runtime\wrap.js:6:10), <anonymous>:248:32)
at eval (eval at wrap (C:\Users\Me\Project\node_modules\pug-runtime\wrap.js:6:10), <anonymous>:379:4)
at template (eval at wrap (C:\Users\Me\Project\node_modules\pug-runtime\wrap.js:6:10), <anonymous>:389:211)
at Object.exports.renderFile (C:\Users\Me\Project\node_modules\pug\lib\index.js:427:38)
at Object.exports.renderFile (C:\Users\Me\Project\node_modules\pug\lib\index.js:417:21)
at View.exports.__express [as engine] (C:\Users\Me\Project\node_modules\pug\lib\index.js:464:11)
at C:\Users\Me\Project\node_modules\engine-munger\index.js:133:22
at C:\Users\Me\Project\node_modules\engine-munger\index.js:154:17
at C:\Users\Me\Project\node_modules\engine-munger\index.js:87:21
at C:\Users\Me\Project\node_modules\engine-munger\index.js:189:13
at FSReqWrap.oncomplete (fs.js:153:5)
知道如何解决这个永恒的问题吗?谢谢!
修改
看来我无法从任何rethinkdb连接或承诺中的data
变量返回任何内容,它必须在它之外才能被检测到。
答案 0 :(得分:1)
尝试用以下代码替换您的代码:
const r = require('rethinkdb');
module.exports = function indexModel() {
return new Promise((resolve, reject) => {
const params = {
host: '127.0.0.1',
port: 28015
};
r.connect(params, (err, conn) => {
// check availability
if (error) return reject(error);
r.db('mydb')
.table('mytable')
.run(conn)
.then(cursor => {
cursor.toArray((error, result) => {
if (error) return reject(error);
const data = JSON.stringify(result, null, 2);
return resolve({
data: data
});
});
});
});
});
}
答案 1 :(得分:1)
使用async/await
可能对您有用
mymodule.js
module.exports = async function IndexModel() {
let conn = await r.connect({host: '127.0.0.1', port: 28015});
let cursor = await r.db('mydb').table('mytable').run(conn)
try {
let arr = await cursor.toArray();
return arr
} catch (e) {
throw e;
}
}
main.js
let indexModel = require('mymodule.js');
indexModel().then(result => {
console.log(result.length)
})