繁体   English   中英

Sails.js / Waterline填充深层嵌套关联

[英]Sails.js/Waterline populate deep nested association

我知道在Sails.js / Waterline中没有内置的方式来填充深层嵌套的关联,所以我试图使用蓝鸟的承诺来实现这一点,但我遇到了一个问题。

我正在成功检索用户,以及与之关联的所有帖子(填充了图像集合)(console.log向我显示所有内容都已正确填充)。 但是,当我覆盖用户的属性“post”并尝试分配之前检索的完全填充的帖子时,它不能正确填充Post.js的images属性。 这就像ORM阻止手动分配Post.js的图像集合。

我究竟做错了什么? 填充深层嵌套的一对多关联的最佳方法是什么?

贝娄我已经粘贴了我正在执行的所有代码....

// Populate nested association
nested: function (req, res, next){
var username = req.param("id");

User
.findOneByUsername(username)
.populateAll()      
.then(function (user){
    var posts = Post.find({
        "user": user.id
    })
    .populate('images')
    .populate('category')
    .then(function (posts){
        return posts;
    });
    return [user, posts];
})
.spread(function (user, posts){
    user.posts = posts; // This won't work.... It assigns all the fields properly but the images collection attribute
    res.json(user);
}).catch(function (err){
    if (err) return res.serverError(err);
});
}

// --- User.js Model --- //
module.exports = {
   attributes: {
    .....,
    posts: {
        collection: "post",
        via: "user"
    },
    .....
   }
 }

// --- Post.js Model --- //
module.exports = {
    attributes: {
       ....,
       user: {
         model: "user"
       },
       images: {
         collection: "postImage",
         via: "post"
       },
       ....
    }
}

// --- PostImage.js Model --- //
module.exports = {

   attributes: {
     ....,
     post: {
       model: "post"
     }
   },
}

问候,

萨维奥卢塞纳

这可能是一个老问题,但最好有一个答案,所以sails.js用户可以从中受益。

你的问题是,当sails返回一条记录(在数组内)时,该记录中与关联对应的键实际上是getter / setter ,而且似乎setter不允许你想要的东西。 您可以使用Object.getOwnPropertyDescriptor(user, 'posts')进行确认。 所以你需要做的就是能够根据需要覆盖该属性,就是在它上面调用.toObject ,(或者通过_.clone克隆它的属性或者手动循环但是你会得到很多垃圾,所以坚持.toObject ),无论如何你得到一个具有你需要的属性的新对象,现在你如何修改它没有任何限制。

所以你的代码看起来像这样:

User
.findOneByUsername(username)
.populateAll()      
.then(function (user){
    var posts = Post.find({
        "user": user.id
    })
    .populate('images')
    .populate('category')
    .then(function (posts){
        return posts;
    });
    return [user, posts];
})
.spread(function (user, posts){
    user = user.toObject() // <- HERE IS THE CHANGE!
    user.posts = posts; // It will work now
    res.json(user);
}).catch(function (err){
    if (err) return res.serverError(err);
});
}

您必须覆盖user.posts数组中的每个post id对象。 有关详细信息,请查看此答案https://stackoverflow.com/a/26452990/4261327

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM