首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根据Id映射对象数组

根据Id映射对象数组
EN

Stack Overflow用户
提问于 2020-04-18 22:52:03
回答 2查看 51关注 0票数 1

这里是Noob javascript爱好者。

我正在尝试理解javascript的各种高阶函数,并且对.map()在对象数组上的可能性特别好奇。

假设您有以下内容:

代码语言:javascript
复制
selectedId = ['u1', 'u2']
data = [
{id: 'u1', color: 'red', age: '24'},
{id: 'u2', color: 'blue', age: '18'},
{id: 'u3', color: 'yellow', age: '15'}
]

如何创建一个只包含u1和u2对象的新数组?即:

代码语言:javascript
复制
selectedData = [
{id: 'u1', color: 'red', age: '24'},
{id: 'u2', color: 'blue', age: '18'},
]
EN

回答 2

Stack Overflow用户

发布于 2020-04-18 22:56:16

您必须对selectedId数组执行Array#map操作,然后使用Array#finddata数组中找到相应的对象。

代码语言:javascript
复制
const selectedId = ['u1', 'u2'];

const data = [
  {id: 'u1', color: 'red', age: '24'},
  {id: 'u2', color: 'blue', age: '18'},
  {id: 'u3', color: 'yellow', age: '15'}
];

const res = selectedId.map((id) => data.find((o) => o.id === id));

console.log(res);

票数 3
EN

Stack Overflow用户

发布于 2020-04-18 23:19:07

如果我理解正确的话,你可以使用数组过滤器,比如

代码语言:javascript
复制
data.filter(el => selectedId.includes(el.id));

会给你

代码语言:javascript
复制
[
{id: 'u1', color: 'red', age: '24'},
{id: 'u2', color: 'blue', age: '18'}
]

或者另选地

代码语言:javascript
复制
selectedId.map((id) => data.find((el) => el.id === id));

会给你

代码语言:javascript
复制
[
{id: 'u1', color: 'red', age: '24'},
{id: 'u2', color: 'blue', age: '18'}
]
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61291141

复制
相关文章

相似问题

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