Sailsjs不在视图中显示模型数据关联

时间:2016-08-28 07:21:48

标签: node.js sails.js

使用Sails.js v0.12.4 和Node.js v6.4.0

我尝试使用MVC将一对多关联显示到特定视图中。

user.js的

module.exports = {
    attributes: {
        tickets: {
            collection: 'ticket',
            via: 'owner'
        }
    }
}

Ticket.js

module.exports = {
    attributes: {
        owner: {
            model: 'user'
        }
    }
}

UserController.js

show: function(req, res, next) {
    User.findOne(req.param('id')).exec(function(err, user) {
        if (err) next(err);
        if (!user) return next();
        res.view({
            user: user,
            userTickets: user.tickets
        });
    });
},

/edit/user/show.ejs

<% _.each(userTickets, function (ticket) { %>
<tr data-id="<%= ticket.id %>" data-model="ticket">
    <td> <%= ticket.id %> </td>
    <td> <%= ticket.ticketName %> </td>

    <td><a href="/ticket/show/<%= ticket.id %>">Show</a></td>
    <td><a href="/ticket/edit/<%= ticket.id %>">Edit</a></td>
    <td><a href="/ticket/destroy/<%= ticket.id %>">Delete</a></td>
</tr>
<% }) %>

我甚至在我的MongoDB数据库中找到关联:

属于以下情况的票证对象:&#34; 57c1207dea46efef0c0cd27d&#34;

{
"_id" : ObjectId("57c27f6de4c7fd2d036a96b5"),
"owner" : ObjectId("57c1207dea46efef0c0cd27d"),
"ticketName" : "asdfasdfasdfasdfasdf",
"createdAt" : ISODate("2016-08-28T06:06:37.085Z"),
"updatedAt" : ISODate("2016-08-28T06:06:37.085Z")
}

用户对象

{
"_id" : ObjectId("57c1207dea46efef0c0cd27d"),
"firstName" : "Dan",
"lastName" : "Michaels",
"email" : "DM@nike.com",
"createdAt" : ISODate("2016-08-27T05:09:17.598Z"),
"updatedAt" : ISODate("2016-08-27T05:09:17.598Z")
}

它在我的/show.ejs页面中没有显示任何内容..

1 个答案:

答案 0 :(得分:0)

变化

User.findOne(req.param('id')).exec(function(err, user) {

User.findOne(req.param('id')).populate('tickets').exec(function(err, user) {

http://sailsjs.org/documentation/reference/waterline-orm/queries/populate

应该这样做。