首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用angular 6过滤两种不同类型的数组(删除重复数据)?

如何使用angular 6过滤两种不同类型的数组(删除重复数据)?
EN

Stack Overflow用户
提问于 2018-11-14 17:43:17
回答 2查看 367关注 0票数 2

代码语言:javascript
复制
array1 = ["one","two"];

array2 = [ {"name":"one","id":101} , {"name":"two","id":102} , {"name":"three","id":103} , {"name":"four","id":104} ];

在上面的数据中,array1是字符串值的集合,array2是对象的集合。现在如何在array2中删除与array1相关的值。我使用for循环编写了代码,但它太长了,所以任何预定义的方法都存在于angular-6/typescript中。

输出:

代码语言:javascript
复制
array2 = [ {"name":"three","id":103} , {"name":"four","id":104} ];
EN

回答 2

Stack Overflow用户

发布于 2018-11-14 17:46:54

您可以利用filterincludes

代码语言:javascript
复制
let finalArray = array2.filter(item=>!array1.includes(item.name))
票数 5
EN

Stack Overflow用户

发布于 2018-11-14 17:51:12

您可以在array1中通过检查名称的index进行过滤

代码语言:javascript
复制
const array3 = array2.filter((item) => array1.indexOf(item.name) < 0);
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53297112

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档