首页 >web前端 >js教程 >如何根据另一个数组中的匹配属性来过滤对象数组?

如何根据另一个数组中的匹配属性来过滤对象数组?

Susan Sarandon
Susan Sarandon原创
2024-10-30 00:34:28422浏览

How can I filter an array of objects based on matching properties in another array?

用另一个对象数组过滤对象数组

这个问题涉及使用对象数组(myArray)过滤对象数组(myArray)我的过滤器)。目标是创建一个新数组 (myArrayFiltered),其中仅包含 myArray 中与基于 userid 和 projectid 的 myFilter 中相应元素相匹配的元素。

考虑以下示例:

myArray = [
  {
    userid: "100",
    projectid: "10",
    rowid: "0"
  },
  {
    userid: "101",
    projectid: "11",
    rowid: "1"
  },
  {
    userid: "102",
    projectid: "12",
    rowid: "2"
  },
  {
    userid: "103",
    projectid: "13",
    rowid: "3"
  },
  {
    userid: "101",
    projectid: "10",
    rowid: "4"
  }
];

myFilter = [
  {
    userid: "101",
    projectid: "11"
  },
  {
    userid: "102",
    projectid: "12"
  },
  {
    userid: "103",
    projectid: "11"
  }
];

预期结果是:

myArrayFiltered = [
  {
    userid: "101",
    projectid: "11",
    rowid: "1"
  },
  {
    userid: "102",
    projectid: "12",
    rowid: "2"
  }
];

为了完成这个任务,我们可以使用过滤器和一些数组方法。这些方法在现代浏览器中广泛使用,并且针对较旧的浏览器存在polyfills。

实现涉及使用filter方法过滤myArray,其中myFilter的每个元素用于与myArray的元素进行比较。然后使用 some 方法来检查 myArray 中当前元素的 userid 和 projectid 属性与 myFilter 中相应元素的 userid 和 projectid 属性之间是否至少存在一个匹配。如果存在匹配,则当前元素将包含在过滤结果中。

下面是演示此方法的示例代码片段:

<code class="javascript">const myArray = [{ userid: "100", projectid: "10", rowid: "0" }, { userid: "101", projectid: "11", rowid: "1"}, { userid: "102", projectid: "12", rowid: "2" }, { userid: "103", projectid: "13", rowid: "3" }, { userid: "101", projectid: "10", rowid: "4" }];
const myFilter = [{ userid: "101", projectid: "11" }, { userid: "102", projectid: "12" }, { userid: "103",  projectid: "11"}];

const myArrayFiltered = myArray.filter((el) => {
  return myFilter.some((f) => {
    return f.userid === el.userid && f.projectid === el.projectid;
  });
});

console.log(myArrayFiltered);</code>

此代码将输出预期结果,提供一个过滤数组,仅包含 myArray 中与 myFilter 中指定的条件匹配的对象。

以上是如何根据另一个数组中的匹配属性来过滤对象数组?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn