如何在.ejs文件上显示所有用户数据库(mongodb)的详细信息

时间:2017-01-22 16:43:07

标签: node.js mongodb express mongoose ejs

我有一个使用本教程构建的node.js网站: https://scotch.io/tutorials/easy-node-authentication-setup-and-local

现在我想在我的一个视图中打印/显示所有用户数据。

在routes.js中

var User = require('../app/models/user'); //the connection to users database
app.get('/profile', isLoggedIn, function (req, res) {
    res.render('profile.ejs', {
        Users: User // get the user out of session and pass to template
    });
});

这是在我的profile.ejs文件中:

<ul>
<% Users.forEach( function(err, user) { %>
<li><%= user %> </li>
<% }); %>

我收到错误:&#34; undefined不是函数&#34;因为&lt;%Users.forEach(函数(错误,用户){%&gt;行

我做错了什么?

1 个答案:

答案 0 :(得分:2)

您需要通过模型的 find() 查询函数实际查询用户集合,该函数将在执行时返回一组用户文档,即

var User = require('../app/models/user'); //the connection to users database
app.get('/profile', isLoggedIn, function (req, res) {
    User.find({}).exec(function(err, users) {   
        if (err) throw err;
        res.render('profile.ejs', { "users": users });
    }
});

然后将profile.ejs中的用户文档列表呈现为:

<% users.forEach(function (user) { %>
    <li>  
        <h1><%= user.name %></h1>  
    </li>                                   
<% }) %>