如何过滤具有可变参数的javascript对象数组

How to filter a javascript object array with variable parameters

本文关键字:参数 变参 javascript 数组 对象 何过滤 过滤      更新时间:2023-09-26

我想根据对象的属性选择对象,但不总是相同的属性。换句话说:

arr = [
    { name: "joe",   age21: 1 },
    { name: "nick",  age21: 0 },
    { name: "blast", age21: 1 }
];
arr.filter(function(item) {
    return (item.name === "nick" && item.age21 === 1);
});

但有时我只想过滤名称例如:

arr.filter(function(item) {
    return (item.name === "nick");
});

我想做的是泛化这一点,以便参数列表可以传递给函数。我想出了以下方法,但速度很慢,我想知道是否有更好的方法:

filterParams = function(arr, params) {
    var new_array = arr.filter(function(item) {
        var select = 1
        for(obj in params) { //create the filter criteria based on varying set of parameters
            var select = select && params[obj] === item[obj];
        }
        return select;
    });
    return new_array;
}

那么你可以用:filterParams(arr, {name: "nick", age21: 1});

或:filterParams(arr, {name: "nick"});

这两种方式都可以

如果你想知道,我这样做是因为我有不同的数据集,我想通过相同的例程运行,所以过滤器属性需要一般化,这样我就可以过滤特定于每个数据集的属性。

谢谢!

这是一个函数式方法,它应该适用于给定对象的任意数量的属性:

function filter(arr, criteria) {
  return arr.filter(function(obj) {
    return Object.keys(criteria).every(function(c) {
      return obj[c] == criteria[c];
    });
  });
}
例如:

var arr = [
  { name: 'Steve', age: 18, color: 'red' },
  { name: 'Louis', age: 21, color: 'blue' }, //*
  { name: 'Mike', age: 20, color: 'green' },
  { name: 'Greg', age: 21, color: 'blue' }, //*
  { name: 'Josh', age: 18, color: 'red' }
];
console.log(filter(arr, { age: 21, color: 'blue' }));
//^ {age:21, color:'blue', name:'Louis}
//  {age:21, color:'blue', name:'Greg'}

不确定你的性能问题,但这应该没问题。

Edit:您可以使用正则表达式使其更强大,例如:

function filter(arr, criteria) {
  return arr.filter(function(obj) {
    return Object.keys(criteria).every(function(c) {
      return new RegExp(criteria[c]).test(obj[c]);
    });
  });
}
console.log(filter(arr, { age: /^2'd$/, color: /^(red|blue)$/ }));
//^ Louis, Greg                --^-- twenty-something
//                                               ----^---- red OR blue