繁体   English   中英

如何使用回调从带有 node.js 和 ejs 的 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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM