简体   繁体   English

如何从 object 数组返回重复元素

[英]how to return duplicates elemements from object array

data= [
  { "id": 0, "name": "name1", "age": 12, "city": "cityA" },
  { "id": 1, "name": "name2", "age": 7, "city": "cityC" },
  { "id": 2, "name": "name3", "age": 23, "city": "cityB" },
  { "id": 2, "name": "name1", "age": 12, "city": "cityA" }
];

how can I return items that have the same name and age?我如何退回具有相同名称和年龄的物品?

im trying something like this but it return every element on array我正在尝试这样的事情,但它返回数组中的每个元素

data.some(d => {
for (const it of form) {
if (it.name == d.name && it.age == d.age) {
arr.push(it)....

You have to make sure that you are not comparing to the same item, where properties always match:您必须确保您没有与同一项目进行比较,其中属性始终匹配:

 data= [ { "id": 0, "name": "name1", "age": 12, "city": "cityA" }, { "id": 1, "name": "name2", "age": 7, "city": "cityC" }, { "id": 2, "name": "name3", "age": 23, "city": "cityB" }, { "id": 2, "name": "name1", "age": 12, "city": "cityA" } ]; const res = data.filter(item => data.some(i => i.== item && item.name === i.name && item.age === i.age)) console.log(res)

If you don't want the first occurrence, you have to check against the already processed elements:如果您不想第一次出现,则必须检查已处理的元素:

 data= [ { "id": 0, "name": "name1", "age": 12, "city": "cityA" }, { "id": 1, "name": "name2", "age": 7, "city": "cityC" }, { "id": 2, "name": "name3", "age": 23, "city": "cityB" }, { "id": 2, "name": "name1", "age": 12, "city": "cityA" } ]; const [result, _] = data.reduce(([duplicates, checked], el) => { checked.some(i => el.name === i.name && el.age === i.age) && duplicates.push(el) return [duplicates, [...checked, el]] }, [[], []] ) console.log(result)

Sort-based approaches are very efficient with that sort of problem:基于排序的方法对于这类问题非常有效:

 data= [ { "id": 0, "name": "name1", "age": 12, "city": "cityA" }, { "id": 1, "name": "name2", "age": 7, "city": "cityC" }, { "id": 2, "name": "name3", "age": 23, "city": "cityB" }, { "id": 2, "name": "name1", "age": 12, "city": "cityA" } ]; const sorted = data.sort( (e1, e2) => e1.name.localeCompare(e2.name) || e1.age - e2.age) const result = sorted.filter( (el, i) => i > 0 && sorted[i-1].name === el.name && sorted[i-1].age === el.age) console.log(result)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM