首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >根据相同的名称分隔数组

根据相同的名称分隔数组
EN

Stack Overflow用户
提问于 2020-09-11 13:30:46
回答 4查看 365关注 0票数 3

我有一个具有相同名称的多个对象的数组。如何根据名称分隔数组?

我试过用地图,过滤器,但没有工作,最后我用的也减少,但没有得到输出。

代码语言:javascript
运行
复制
 const result = Object.values(this.optionsArr.reduce((a, c) => {
        a[c.name] = a[c.name] || {name: c.name};
        a[c.name].options.push(c.options);
        return a;
      }, {})).map(item => ({...item, accessDetails: Object.values(item.accessDetails)}));

投入:

代码语言:javascript
运行
复制
[{name: "audio", options:{name:'true', value: 'T'}},
{name: "audio", options:{name:'false', value: 'F'}},
{name: "audio", options:{name:'yes', value: 'Y'}},
{name: "video", options:{name:'true', value: 'T'}},
{name: "video", options:{name:'yes', value: 'Y'}},
{name: "video", options:{name:'false', value: 'F'}},
{name: "call", options:{name:'true', value: 'T'}},
{name: "call", options:{name:'No', value: 'N'}},
{name: "call", options:{name:'false', value: 'F'}}]

预期产出

代码语言:javascript
运行
复制
 [{name: "audio", options:[{name:'true', value: 'T'},{name:'false', value: 'F'},{name:'yes', value: 'Y'}]},
    {name: "video", options:[{name:'true', value: 'T'},{name:'false', value: 'F'},{name:'yes', value: 'Y'}]},
    {name: "call", options:[{name:'true', value: 'T'},{name:'false', value: 'F'},{name:'yes', value: 'Y'}]}]
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2020-09-11 13:41:06

您可以使用对象来存储同名的元素,从而执行约简操作。

代码语言:javascript
运行
复制
const arr = [{name: "audio", options:{name:'true', value: 'T'}},
{name: "audio", options:{name:'false', value: 'F'}},
{name: "audio", options:{name:'yes', value: 'Y'}},
{name: "video", options:{name:'true', value: 'T'}},
{name: "video", options:{name:'yes', value: 'Y'}},
{name: "video", options:{name:'false', value: 'F'}},
{name: "call", options:{name:'true', value: 'T'}},
{name: "call", options:{name:'No', value: 'N'}},
{name: "call", options:{name:'false', value: 'F'}}];
const res = Object.values(arr.reduce((acc,{name, options})=>{
  acc[name] = acc[name] || {name, options: []};
  acc[name].options.push(options);
  return acc;
}, {}));
console.log(res);

票数 2
EN

Stack Overflow用户

发布于 2020-09-11 13:52:59

使用reduce是正确的,但是您可以减少项目并将其推到Array上,这样可以为您提供所需的输出,而不是还原为Object

代码语言:javascript
运行
复制
this.optionsArr.reduce((p, c) => {
   if (!p.some(a => a.name === c.name)) {
        p.push({ name: c.name, options: []});
   }
   p.find(a => a.name === c.name).options.push(c.options);
   return p;
}, []);
票数 0
EN

Stack Overflow用户

发布于 2020-09-11 14:02:39

您的代码几乎是正确的,您只是忘了作为一个空数组启动选项,所以推送可以工作:

, options: []添加到还原函数中的第一个内联中

代码语言:javascript
运行
复制
 const result = Object.values(this.optionsArr.reduce((a, c) => {
        a[c.name] = a[c.name] || {name: c.name, options: []};
        a[c.name].options.push(c.options);
        return a;
      }, {})).map(item => ({...item, accessDetails: Object.values(item.accessDetails)}));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63848094

复制
相关文章

相似问题

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