angular – 是否可以在Typescript中按值“过滤”Map?
发布时间:2020-12-17 17:36:38 所属栏目:安全 来源:网络整理
导读:我正在寻找一种通过值而不是键来过滤地图的方法.我有一个在我的Angular应用程序中建模如下的数据集: { "85d55e6b-f4bf-47bb-a988-78fdb9650ef0": { is_deleted: false,public_email: "007@example.org",id: "85d55e6b-f4bf-47bb-a988-78fdb9650ef0",modifie
我正在寻找一种通过值而不是键来过滤地图的方法.我有一个在我的Angular应用程序中建模如下的数据集:
{ "85d55e6b-f4bf-47bb-a988-78fdb9650ef0": { is_deleted: false,public_email: "007@example.org",id: "85d55e6b-f4bf-47bb-a988-78fdb9650ef0",modified_at: "2017-09-26T15:35:06.853492Z",social_url: "https://facebook.com/jamesbond007",event_id: "213b01de-da9e-4d19-8e9c-c0dae63e019c",visitor_id: "c3c232ff-1381-4776-a7f2-46c177ecde1c",},} 这些条目上的键与条目值上的id字段相同. 给定其中的几个条目,我想过滤并返回一个新的Map(),它只包含那些带有给定event_id的条目.如果这是一个数组,我会做以下事情: function example(eventId: string): Event[] { return array.filter((item: Event) => item.event_id === eventId); } 本质上,我试图复制Array.prototype.map()的功能 – 只是在Map而不是Array上. 我愿意使用Lodash,如果它能以更简洁的方式帮助实现这一点,因为它已经在我的项目中可用. 解决方法
它是
Array.from(map.values()).filter((item: Event) => item.event_id === eventId); 或者对于TypeScript [...map.values()].filter((item: Event) => item.event_id === eventId); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |