首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从MongoDB到FrontEnd显示项目

从MongoDB到FrontEnd显示项目
EN

Stack Overflow用户
提问于 2019-01-08 17:56:03
回答 2查看 74关注 0票数 0

我在MongoDB数据库中有一个嵌套数组,我希望使用Jade和Express在前端显示它。

我在显示它们时遇到了一些问题:

这是我希望显示的嵌套项目:

MongoDB:

代码语言:javascript
复制
{
    "_id" : ObjectId("5c3343913d1e1323111fce6f"),
    "title" : "Projecten",
    "__v" : 0,
    "sub_items" : [ 
        {
            "title" : "item1"
        }, 
        {
            "title" : "item2"
        }
    ]
}

Mongoose模型:

代码语言:javascript
复制
var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var menuItems = new mongoose.Schema({
  sub_items : {
    title: String
  }
}, {collection: 'menu_items'});

module.exports = mongoose.model("menu_items", menuItems);

我使用Express发布嵌套项,如下所示:

代码语言:javascript
复制
postController.updateSubItems = function(req,res,item) {
  var id = req.body.id;
  var saveData = {
    title: req.body.sub_item
  };
  item.update({_id: id}, {$addToSet:{sub_items: saveData}}, (err, result) => {
  });
};

在玉石中的显示如下:

代码语言:javascript
复制
each item in data
   p #{item.sub_items}

最终结果是这样的:

代码语言:javascript
复制
item1,item2

类似于字符串,但我希望将它们作为单个项显示

EN

回答 2

Stack Overflow用户

发布于 2019-01-08 18:15:12

根据您的sub_items对象,尝试下面的代码

代码语言:javascript
复制
  each item in [{sub_items:'sub_item_1'}]
   p=item.sub_items

将上述代码粘贴到此editor

票数 0
EN

Stack Overflow用户

发布于 2019-01-08 18:23:55

我不确定在Jade中是否有更优雅的方法来实现这一点,但我只是使用了@iamwebkalakaar建议的编辑器,测试了以下代码片段,它似乎可以正确打印:

each item in [{"sub_items" : [{"title" : "item1"}, {"title" : "item2"}]}] each subitem in item.sub_items p=subitem.title

新代码段

代码语言:javascript
复制
- var data = { "title" : "Projecten", "__v" : 0, "sub_items" : [ { "title" : "item1" }, { "title" : "item2" } ] };

 each subitem in data.sub_items
   p=subitem.title 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54089247

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档