无法查询从Mongodb返回的类似数组的对象

时间:2014-05-22 14:19:16

标签: javascript node.js mongodb mongoose

使用node.js / express和mongoose(mongodb)和护照。我无法获得返回的类似数组的对象的键/值对。 用户模型:

{ 
 local : {
   email     : String,
   password  : String
},
 skills : {
  skill     : String,
  level     : Number
 }
}

我可以像这样向用户添加新技能:完全按预期工作

app.post( '/addskill', function ( req, res ) {
    var newskill = {skill : req.body.skill,  level : req.body.level};
    User.findByIdAndUpdate( req.user.id,
     { $push: { skills: newskill }}, 
     function (err, user ) {
      res.redirect('/profile');
    });
});

我可以轻松访问我的ejs文件中的电子邮件和密码字符串,如下所示:

<%= user.local.email %>
<%= user.local.password %>

当我用

查询数据库时
user.skills

我可以用这种格式获得所有技能:

[ { skill: 'qwe', level: 1 }, { skill: 'html', level: 1 }, { skill: 'python', level: 4 } ]

再一次,正是我在寻找的东西。我现在要做的是创建一个列出技能和水平的表格。

所有数组方法似乎都不起作用 我试过ejs模板文件。

user.skills.forEach()  -- not working 'user' is null
user.forEach --  works to create a list of users.
user.skills[0].skill  -- not working
user.skills[i].skill -- in var loop, not working

这是错误消息:

Object [ { skill: 'qwe', level: 1 }, { skill: 'html', level: 1 }, 
{ skill: 'python', level: 4 } ] has no method 'forEach' at eval ...

所以我的问题是:如何访问此集合中的键值对(数组?)

谢谢!

1 个答案:

答案 0 :(得分:0)

所以这里的解决方案是在你的猫鼬模型中定义一个数组:

我所要做的就是将[]添加到&#39;技能&#39;部分:

{ 
 local : {
   email     : String,
   password  : String
},
 skills : [{
  skill     : String,
  level     : Number
 }]
}

现在所有数组方法都有效!!