Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/backbone.js/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 使用ID数组筛选和排序主干集合_Javascript_Backbone.js_Underscore.js_Sorting - Fatal编程技术网

Javascript 使用ID数组筛选和排序主干集合

Javascript 使用ID数组筛选和排序主干集合,javascript,backbone.js,underscore.js,sorting,Javascript,Backbone.js,Underscore.js,Sorting,我是个新手,所以我遇到了一些我不太明白的问题 我有一个超过100个项目的主干收集。我想用一个ID数组来过滤它们,这很好,但是我希望项目的顺序也基于这个数组的项目顺序。这是行不通的。其他排序方法似乎是基于逻辑的,这也不是我需要的。是否可以使用此筛选器获取项目,然后按照我定义的顺序将其放入集合中 我有一个用于筛选的id数组,该数组如下所示: var dDefaultItems = ['1','2','146','3','4','9','26','8','96','10','11','54','145

我是个新手,所以我遇到了一些我不太明白的问题

我有一个超过100个项目的主干收集。我想用一个ID数组来过滤它们,这很好,但是我希望项目的顺序也基于这个数组的项目顺序。这是行不通的。其他排序方法似乎是基于逻辑的,这也不是我需要的。是否可以使用此筛选器获取项目,然后按照我定义的顺序将其放入集合中

我有一个用于筛选的id数组,该数组如下所示:

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 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;
    }

 });
然后我用这段代码在一个视图中呈现这段代码(还有其他一些用于定义模型和其他属性的代码,我认为它们不相关,我可能错了,但我认为有人会从这段代码中知道我需要什么。)


主干集合将按照插入顺序自动排序,除非您实现
集合#比较器
。问题是过滤算法没有生成有序的输出

如果只在按id筛选时需要维护有序集合,我建议实现一个单独的方法,因为按id搜索比按任意属性搜索快得多:

filterById: function(idArray) {
  return this.reset(_.map(idArray, function(id) { return this.get(id); }, this));  
}
用法:

collection.filterById(['1', '2', '146', '3', '4', '9', '26', '8', '96', '10', '11', '54',' 145', '273', '38']);

正是我需要的,谢谢!我只需要将结果转换成JSON就可以让它100%工作。这是一个非常聪明的方法。