我将从mongoDB数据的外观开始:
_id : 5c5b450918cb2b121648ff7a
name : "dannondarko"
email : "dangilmail@gmail.com"
password : "$2a$10$3z5m1e9Pcfid72Q2GchCjeTD55/SsIxmtWr3I1ZiA.DX/KlpfTbdK"
date : 2019-02-06 20:35:21.973
__v : 0
posts : Array
0 : Object
note : "test for the user dannondarko"
date : "02/08/2019"
这只是一个附带项目,很可能永远不会上线,所以不必担心我发布此数据的安全性!至于我如何处理服务器代码中的代码:
app.get('/:username', (req, res) => {
username = req.params.username.toLowerCase();
const collection = req.app.locals.collection;
collection.find({ name: username }).toArray(function (err, results) {
if (err) {
res.status(500).send("Error communicating with the DB.");
} else if (results.length > 0) {
console.log("Here are the results: " + results);
console.log({people: results});
res.status(200).render('profile', {posts: results, name: username});
} else {
next();
}
});
});
我对这段代码所做的事情是说您转到地址栏“ / dannondarko”,它应该在集合中找到“ dannondarko”,这很好,然后“ results”变量是该对象的完整对象。我在上面发布了。我正在尝试做的只是获取“帖子”数据,例如注释和日期。
注释和日期是我唯一需要的数据,它将被发送到此.ejs文件,该文件应创建一个显示用户注释和发布日期的帖子(类似于FB)。这是我的.ejs文件:
<h1 class="mt-4"><%= name %></h1>
<div class="container">
<br>
<% for(var i=0; i < posts.length; i++) { %>
<div class="container">
<label><%= posts[i].note %></label>
<div class="container">
<label><%= posts[i].date %></label>
</div>
</div>
<% } %>
</div>
我希望有足够的信息。我相信我的失败并不知道如何仅从特定用户的MongoDB中提取“帖子”数组,然后遍历对象并将注释和日期发送到.ejs。
答案 0 :(得分:1)
results
是一个文档数组,您将该数组以posts
的形式呈现给ejs。现在,在您的ejs文件中,posts
代表文档数组,而不是posts
数组。因此,如果要遍历所有结果,则应按以下方式编辑代码:
<% posts.forEach(post => { %>
<h1 class="mt-4"><%= post.name %></h1>
<div class="container">
<br>
<% post.posts.forEach(p => { %>
<div class="container">
<label><%= p.note %></label>
<div class="container">
<label><%= p.date %></label>
</div>
</div>
<% }) %>
</div>
<% }) %>
如果我对您的mongo模型结构了如指掌,那么上面的内容应该会对您有所帮助。