You*_*ere 2 javascript arrays mongoose mongodb node.js
我有一个PlaylistShema与阵列或音乐.在这一系列的音乐中,我有一个ObjectId(谁参考音乐收藏),一个addedAt和一个title.
PlaylistShema
var PlaylistSchema = new Schema({
title: {type : String, default : '', trim : true},
user: {type : Schema.ObjectId, ref : 'User'},
musics : [{
musicId : {type : Schema.ObjectId , ref : 'Music'},
title : {type : String},
addedAt : {type : Date, default : Date.now}
}],
tags : { type : [], get : getTags, set : setTags},
createdAt : {type : Date, default : Date.now}
})
Run Code Online (Sandbox Code Playgroud)
我有一个静态加载播放列表:
加载功能
load: function (id, cb) {
this.findOne({ _id : id })
.populate('user', 'name email username')
.populate('musics.musicId')
.exec(cb)
}
Run Code Online (Sandbox Code Playgroud)
我想通过addedAt... 来排序我的音乐...
但我不能这样做,.populate('musics.musicId', { sort: { 'addedAt': 'desc' } })因为这不是addedAt...
当涉及到嵌套数组时,我对populate非常困惑...
谢谢 !
MusicShema
var MusicSchema = new Schema({
title: {type : String, default : '', trim : true}
})
Run Code Online (Sandbox Code Playgroud)
您无法直接在Mongoose中对数组进行排序.您可以使用toObject(文档)和Array sort方法克隆数据并将其排序为JavaScript对象:
Playlist.load(function(err, playList) {
var pl = playList.toObject();
pl.musics.sort(function(m1, m2) { return m1.addedAt - m2.addedAt; });
// pl contains the playlist now
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6288 次 |
| 最近记录: |