用另一个对象数组过滤对象数组
这个问题涉及使用对象数组(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中文网其他相关文章!