Фильтровать и сортировать коллекцию магистралей с массивом идентификаторов
Я совсем новичок в Backbone, поэтому у меня возникают проблемы, которые я не могу понять.
У меня есть коллекция Backbone с более чем 100 предметами. Я хочу отфильтровать их с помощью массива идентификаторов, который работает нормально, но я хочу, чтобы порядок элементов также основывался на порядке элементов этого массива. Это не работает. Другие методы сортировки, по-видимому, основаны на асибете, но это не то, что мне нужно. Можно ли получить элементы с помощью этого фильтра, а затем поместить их в коллекцию в порядке, который я определил?
У меня есть массив идентификаторов, которые я фильтрую, этот массив выглядит так:
var dDefaultItems = ['1','2','146','3','4','9','26','8','96','10','11','54','145','273','38'];
Код для сбора и фильтрации выглядит следующим образом:
var ChannelCollection = Backbone.Collection.extend({
fetch : function() {
var params = _.extend({}, arguments, {
data : {
"groupnumber" : "1000"
}
});
this.constructor.__super__.fetch.apply(this, [params]);
},
model : Channel,
url : function () {
return utility.apiUrl('/myurl/tothething');
},
filterData: function(params) {
this.originalModels = this.models.slice();
_.each(params, function(val, key){
if (typeof val !== 'object') val = [ val ];
this.models = _.filter(this.models, function(model){
return _.indexOf(val, model.get(key)) !== -1;
}, this);
}, this);
return this.reset(this.models).toJSON();
},
parse : function(json) {
return json.channelInfoList;
}
});
Затем я отображаю это в виде с помощью этого кода (есть другие фрагменты кода для определения модели и других атрибутов, которые я не считаю релевантными, я могу ошибаться, но я думаю, что кто-то узнает, что мне нужно, глядя на это.)
var ChannelListView = Backbone.View.extend({
initialize: function() {
var _this = this;
currentChannelList = new ChannelCollection();
currentChannelList.once("sync", function() {
_this.render();
});
currentChannelList.fetch();
},
render : function() {
var _this = this;
$(_this.el).empty();
dust.render("list-channels", { channelList : currentChannelList.filterData({id: dDefaultItems})} , function(err, html) {
var $el = $(html).appendTo($(_this.el));
});
}
});