[英]How to pass an object from EJS to Node.js Router - Javascript, EJS, Node.js, MySQL
[英]How do I use a callback to fetch data from mysql with node.js and ejs?
我需要从下面的查询中获取foo
:
exports.get = function(id, cb) {
sql = 'SELECT `sidebar`, `test` FROM users WHERE `id` = "' + id + '"';
con.query(sql, function(err, foo) {
if (err) { return cb(err) }
else { return cb(foo) };
});
}
然后像这样在我的 app.js 上渲染foo
:
app.get('/dashboard', ensureLoggedIn('/login'),
function(req, res) {
const id = req.session.passport.user;
const foo = db.defaults.set(id) //db.defaults.set calls the query
console.log(foo); //prints undefined
res.render('dashboard', { foo:foo });
});
这是我最近的尝试:
app.get('/dashboard', ensureLoggedIn('/login'),
function(req, res, next) {
const id = req.session.passport.user;
db.defaults.get(id, function(err, foo) {
if (err) return next(err);
res.render('dashboard', {foo:foo});
//also tried:
//return res.render('dashboard', {foo:foo});
});
上面的尝试根本不呈现页面。 html加载为:
[object object]
我错过了什么?
您正在尝试异步呈现服务器端模板(在获取数据之后),但您不能这样做。
您可以做的是将模板同步发送到客户端,然后公开一个端点以获取这些数据并相应地修改页面(在客户端上)。
app.get('/dashboard', ensureLoggedIn('/login'), function(req, res) {
res.render('dashboard');
});
app.get('/fetchdata', function (req, res, next) {
const id = req.session.passport.user;
db.defaults.get(id, function(err, foo) {
if (err) return next(err);
res.send(foo);
});
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.