我正在制作带有ejs视图引擎的第一个Node.js应用程序。我有两个模型:帖子和用户。我已经尝试将这两个模型链接在一起,但似乎无法弄清楚如何显示用户发布了哪些帖子!
这是用户模型:
// User Schema
var UserSchema = mongoose.Schema({
username: {
type: String,
index:true
},
password: {
type: String
},
email: {
type: String
},
name: {
type: String
},
facebook : {
id : String,
token : String
},
posts : [{ type: mongoose.Schema.Types.ObjectId, ref: 'Post' }]
});
这是帖子:
// Post Schema
var PostSchema = mongoose.Schema({
user: {type: mongoose.Schema.ObjectId, ref: 'User'},
name: {
type: String,
index:true
},
text: {
type: String
}
});
这是我显示帖子的控制器/路线:
// Post page
router.get('/post', function(req, res){
req.db.collection('posts').find().toArray((err, result) => {
if (err) return console.log(err)
res.render('posts/post', {posts: result, req: req});
})
});
如果我在我的视图文件(ejs)中有这个:
<%posts.forEach(function(element){%>
<li>
<%=element.name%> <br>
<%=element.text%> <br>
<%=element.user.username %>
</li>
<br>
<%});%>
我得到&#34;用户名&#34;的输出是&#34;未定义&#34;
如果我改为:
<%posts.forEach(function(element){%>
<li>
<%=element.name%> <br>
<%=element.text%> <br>
<%=element.user %>
</li>
<br>
<%});%>
我的用户名为:d6cf225e(我的用户ID)。
为什么我无法通过添加&#34; .username&#34;来检索我的用户名?当我添加一个新帖子时,似乎所有信息都在那里。在我的控制台中,我可以看到插入了以下消息:
{ __v: 0,
name: 'lol',
text: 'test',
user:
{ _id: d6cf225e,
username: 'Test',
email: 'test@test.se',
name: 'Test',
__v: 0,
posts: [],
facebook:
{ token: 'TOKENNUMBER'
id: '23123123' } },
_id: 2d8afa19fbf6 }
更新控制器以填充用户。它现在有效。
// Post page
router.get('/post', function(req, res){
Post.find().populate('user').exec(function(err, result) {
if (err) return console.log(err)
res.render('posts/post', {posts: result});
})
});
答案 0 :(得分:1)
当您在帖子架构中引用您的用户时,您需要将 Mongoose 告诉用户populate。如果不这样做,您将只在查询结果中获得对用户的ObjectId引用。
req.db.collection('posts')
.find()
.populate('user')
.toArray((err, result) => {
// logic here
})
我不认为 ejs 与此有关,因为它只是渲染引擎。
在您的插入中,您可能会发送所有用户信息,但我不确定,因为您没有向我们展示您的插入查询的完整代码。