簡體   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