9

我已经搜索了相当长的一段时间,但无法获得带有 or 条件的 where 子句的方法。例如,如果我有一个集合Cars并且我尝试执行以下操作:

Cars.where({
            model: 1998,
            color: 'Black',
            make: 'Honda' 
          })

car所以上面要做的是搜索一个who modelis 1998AND coloris BlackAND makeis Honda

但是我需要一种方法来获得cars满足三个条件中的任何一个的条件。

4

2 回答 2

11
Cars.filter(function(car) {
    return car.get("model") === 1998 ||
        car.get("color") === "Black" ||
        car.get("make") === "Honda";
});
于 2013-01-08T04:12:19.313 回答
0

我知道这是一个旧帖子,但也许这对某人有用。

我有一个类似的问题,但有点简单,这就是我解决它的方法

var ids=[1,2,3,4];
var plans=this.collection.filter(function(plan){
            var rt=false;
            for(var i=0;i<this.whereOR.length;i++){
                rt=rt||plan.get('id')==this.whereOR[i];
            }
            return rt;
        },{whereOR:ids});

我认为这可以适用于解决这样提出的问题:

var search={model: 1998,color: 'Black',make: 'Honda'};
Cars.filter(function(car){
                var rt=false;

                for(key in this.whereOR) {
                    rt=rt||car.get(key)==this.whereOR[key];
                }
                return rt;
            },{whereOR:search});)

希望这对某人有帮助!

于 2015-01-08T20:35:48.623 回答