94

我有一组对象,我想知道搜索它的最佳方法。鉴于以下示例,我如何搜索name = "Joe"and age < 30?有什么 jQuery 可以提供帮助,还是我必须自己强制执行此搜索?

var names = new Array();

var object = { name : "Joe", age:20, email: "joe@hotmail.com"};
names.push(object);

object = { name : "Mike", age:50, email: "mike@hotmail.com"};
names.push(object);

object = { name : "Joe", age:45, email: "mike@hotmail.com"};
names.push(object);
4

8 回答 8

144

现代解决方案Array.prototype.filter()

const found_names = names.filter(v => v.name === "Joe" && v.age < 30);

或者,如果您仍然使用 jQuery,您可以使用jQuery.grep()

var found_names = $.grep(names, function(v) {
    return v.name === "Joe" && v.age < 30;
});
于 2012-11-27T23:04:38.400 回答
81

您可以使用以下[].filter方法轻松完成此操作:

var filterednames = names.filter(function(obj) {
    return (obj.name === "Joe") && (obj.age < 30);
});

您可以在此 MDN 页面上了解有关它的更多信息。

于 2012-11-27T23:05:52.397 回答
9

您可以利用jQuery.filter()函数从匹配元素的子集中返回元素。

var names = [
    { name : "Joe", age:20, email: "joe@hotmail.com"},
    { name : "Mike", age:50, email: "mike@hotmail.com"},
    { name : "Joe", age:45, email: "mike@hotmail.com"}
   ];
   
   
var filteredNames = $(names).filter(function( idx ) {
    return names[idx].name === "Joe" && names[idx].age < 30;
}); 

$(filteredNames).each(function(){
     $('#output').append(this.name);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<div id="output"/>

于 2014-09-26T07:50:32.420 回答
9

var nameList = [
{name:'x', age:20, email:'x@email.com'},
{name:'y', age:60, email:'y@email.com'},
{name:'Joe', age:22, email:'joe@email.com'},
{name:'Abc', age:40, email:'abc@email.com'}
];

var filteredValue = nameList.filter(function (item) {
      return item.name == "Joe" && item.age < 30;
});

//To See Output Result as Array
console.log(JSON.stringify(filteredValue));

你可以简单地使用 javascript :)

于 2017-01-24T15:46:01.607 回答
7

对于那些想要使用任何键从对象数组中过滤的人:

function filterItems(items, searchVal) {
  return items.filter((item) => Object.values(item).includes(searchVal));
}
let data = [
  { "name": "apple", "type": "fruit", "id": 123234 },
  { "name": "cat", "type": "animal", "id": 98989 },
  { "name": "something", "type": "other", "id": 656565 }]


console.log("Filtered by name: ", filterItems(data, "apple"));
console.log("Filtered by type: ", filterItems(data, "animal"));
console.log("Filtered by id: ", filterItems(data, 656565));

从 JSON 对象数组中过滤:**

于 2019-09-06T10:12:19.277 回答
3

var names = [{
        name: "Joe",
        age: 20,
        email: "joe@hotmail.com"
    },
    {
        name: "Mike",
        age: 50,
        email: "mike@hotmail.com"
    },
    {
        name: "Joe",
        age: 45,
        email: "mike@hotmail.com"
    }
];
const res = _.filter(names, (name) => {
    return name.name == "Joe" && name.age < 30;

});
console.log(res);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.5/lodash.js"></script>

于 2018-04-24T12:30:31.417 回答
1

这么快的问题。如果您有两个对象数组,并且您想“对齐”这些对象数组,以便确保每个数组的对象与另一个数组的顺序相同,该怎么办?如果您不知道数组中的任何对象包含哪些键和值怎么办......更不用说它们的顺序是什么了?

因此,您的 , 等需要一个“通配符表达式” [].filter[].map如何获得通配符表达式?

var jux = (function(){
    'use strict';

    function wildExp(obj){
        var keysCrude = Object.keys(obj),
            keysA = ('a["' + keysCrude.join('"], a["') + '"]').split(', '),
            keysB = ('b["' + keysCrude.join('"], b["') + '"]').split(', '),
            keys = [].concat(keysA, keysB)
                .sort(function(a, b){  return a.substring(1, a.length) > b.substring(1, b.length); });
        var exp = keys.join('').split(']b').join('] > b').split(']a').join('] || a');
        return exp;
    }

    return {
        sort: wildExp
    };

})();

var sortKeys = {
    k: 'v',
    key: 'val',
    n: 'p',
    name: 'param'
};
var objArray = [
    {
        k: 'z',
        key: 'g',
        n: 'a',
        name: 'b'
    },
    {
        k: 'y',
        key: 'h',
        n: 'b',
        name: 't'
    },
    {
        k: 'x',
        key: 'o',
        n: 'a',
        name: 'c'
    }
];
var exp = jux.sort(sortKeys);

console.log('@juxSort Expression:', exp);
console.log('@juxSort:', objArray.sort(function(a, b){
    return eval(exp);
}));

您还可以在每个对象的迭代中使用此函数来为每个对象中的所有键创建更好的集体表达式,然后以这种方式过滤您的数组。

这是我几乎完成的 API Juxtapose 的一个小片段,它做到了这一点,对象相等与豁免、对象统一和数组压缩。如果这些是您的项目需要或想要的东西,请发表评论,我会尽快使该库可访问。

希望这可以帮助!快乐编码:)

于 2013-11-09T05:59:30.260 回答
1

最直接和易读的方法是使用原生 javascript 过滤器方法。

本机 JavaScript 过滤器采用声明式方法过滤数组元素。由于它是在 Array.prototype 上定义的方法,因此它在提供的数组上进行迭代并在其上调用回调。这个回调函数,作为我们的过滤函数,接受三个参数:

element— 被迭代的数组中的当前项

index— 被迭代的数组中当前元素的索引或位置

array— 应用过滤器方法的原始数组让我们在一个例子中使用这个过滤器方法。请注意,过滤器可以应用于任何类型的数组。在此示例中,我们将根据对象属性过滤对象数组。

根据对象属性过滤对象数组的示例如下所示:

// Please do not hate me for bashing on pizza and burgers.
// and FYI, I totally made up the healthMetric param :)
let foods = [
  { type: "pizza", healthMetric: 25 },
  { type: "burger", healthMetric: 10 },
  { type: "salad", healthMetric: 60 },
  { type: "apple", healthMetric: 82 }
];
let isHealthy = food => food.healthMetric >= 50;

const result = foods.filter(isHealthy);

console.log(result.map(food => food.type));
// Result: ['salad', 'apple']

要了解有关在函数中过滤数组并构建自己的过滤的更多信息,请查看这篇文章: https ://medium.com/better-programming/build-your-own-filter-e88ba0dcbfae

于 2020-04-16T13:35:53.827 回答