按照分组名称和子项对对象数组进行分组。
创始人
2024-08-24 00:00:42
0

假设有一个对象数组,每个对象包含一个分组名称和各个子项,要将这些对象按照分组名称和子项进行分组,可以使用reduce和对象的key来实现:

const data = [
  { group: 'A', children: ['a1', 'a2', 'a3'] },
  { group: 'B', children: ['b1', 'b2', 'b3'] },
  { group: 'A', children: ['a4', 'a5'] },
  { group: 'C', children: ['c1', 'c2', 'c3'] },
  { group: 'B', children: ['b4', 'b5', 'b6'] },
];

const result = data.reduce((acc, item) => {
  // 如果当前分组名称不存在,则添加该分组
  if (!acc[item.group]) {
    acc[item.group] = {};
  }
  
  // 将当前子项加入对应的分组中
  item.children.forEach(child => {
    if (!acc[item.group][child]) {
      acc[item.group][child] = [];
    }
    acc[item.group][child].push(item);
  });
  
  return acc;
}, {});

console.log(result);

// 输出结果:
// {
//   "A": {
//     "a1": [
//       {
//         "group": "A",
//         "children": [
//           "a1",
//           "a2",
//           "a3"
//         ]
//       }
//     ],
//     "a2": [
//       {
//         "group": "A",
//         "children": [
//           "a1",
//           "a2",
//           "a3"
//         ]
//       }
//     ],
//     "a3": [
//       {
//         "group": "A",
//         "children": [
//           "a1",
//           "a2",
//           "a3"
//         ]
//       }
//     ],
//     "a4": [
//       {
//         "group": "A",
//         "children": [
//           "a4",
//           "a5"
//         ]
//       }
//     ],
//     "a5": [
//       {
//         "group": "A",
//         "children": [
//           "a4",
//           "a5"
//         ]
//       }
//     ]
//   },
//   "B": {
//     "b1": [
//       {
//         "group": "B",
//         "children": [
//           "b1",
//          

相关内容

热门资讯

值得注意的是!微信新众游辅助,... 值得注意的是!微信新众游辅助,好像是有辅助神器(有挂细节)-哔哩哔哩1、微信新众游辅助辅助器安装包、...
现有关情况通报如下!赣湘互娱怎... 现有关情况通报如下!赣湘互娱怎么下载辅助,本来真的有辅助app(真的有挂)-哔哩哔哩1、操作简单,无...
做出回应!微信游戏决胜游戏辅助... 做出回应!微信游戏决胜游戏辅助,竟然是有辅助修改器(新版有挂)-哔哩哔哩1、实时微信游戏决胜游戏辅助...
做出回应!天天互娱辅助器免费下... 您好,天天互娱辅助器免费下载这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】...
据通报!贵阳辅助工具,果然有挂... 据通报!贵阳辅助工具,果然有挂辅助工具(真的有挂)-哔哩哔哩1、贵阳辅助工具辅助器安装包、贵阳辅助工...
最新消息!越乡游义乌辅助器下载... 最新消息!越乡游义乌辅助器下载,原来真的有辅助安装(有挂细节)-哔哩哔哩亲,关键说明,越乡游义乌辅助...
刚刚!威信茶馆解码器,原来存在... 刚刚!威信茶馆解码器,原来存在有辅助脚本(有挂功能)-哔哩哔哩1、上手简单,内置详细流程视频教学,新...
迎来新发展!长春科乐天天踢辅助... 迎来新发展!长春科乐天天踢辅助,一直真的有辅助脚本(有挂技术)-哔哩哔哩1、长春科乐天天踢辅助脚本辅...
现就发布提示!宜宾小闲辅助,好... 现就发布提示!宜宾小闲辅助,好像存在有辅助器(的确有挂)-哔哩哔哩1、许多玩家不知道宜宾小闲辅助辅助...
值得注意的是!海洋麻将辅助器,... 值得注意的是!海洋麻将辅助器,一贯真的有辅助工具(真是有挂)-哔哩哔哩1、起透看视 海洋麻将辅助器辅...