1

我正在使用带有 mysqljs 模块的 SQL 数据库构建书店应用程序,我可以从数据库中获取所有书籍,但我想访问一本书并显示其详细信息。

我通过它的 id 获取 book 对象并在控制台中显示它

书籍详情路线:

/* GET Book Details page. */
router.get('/details/:id', function(req, res, next) {
    var sql = `SELECT * FROM books WHERE id = ${req.params.id}`;
    var query = db.query(sql, function (err, result) {
        if(err) throw err;
        console.log(result);
        var model = {result: result}
        res.render('shop/details', { title: 'Books', model });
    });
});

在控制台上显示这个

这是控制台显示的内容

在我写的车把代码中

<h1 class="text-center">Book Details Here</h1>
<h3> Your Book Name is {{this.BookName}}</h3>

但它只显示“你的书名是”没有书名

4

1 回答 1

0

它看起来像您的模板,期望 Book 对象作为上下文,并且在您的示例代码中,您向它传递了一个结果键,该键被映射到包含 book 对象的数组中。

以下是我通常调试此类问题的方式:我会将对象文字作为上下文传递,以确保渲染方法按预期工作。

res.render('shop/details', { title: 'Books', {BookName: 'Season of migration to the north',id: 198} });

如果这可行,那么您需要更改传递给页面的模型。因此,您将传递 request[0];

如果这不起作用,我会将整个上下文对象记录到模板中以对其进行调试。这篇文章应该可以帮助您如何做到这一点:在模板中显示 Handlebars.js 上下文

祝你好运!

于 2018-05-20T19:08:37.843 回答