遍历MongoDB对象的数据

时间:2019-02-09 18:14:53

标签: node.js mongodb express ejs

我将从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。

1 个答案:

答案 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模型结构了如指掌,那么上面的内容应该会对您有所帮助。