0

0

JavaScript 对象数组按属性层级分组生成嵌套树结构

霞舞

霞舞

发布时间:2026-02-09 13:09:39

|

458人浏览过

|

来源于php中文网

原创

JavaScript 对象数组按属性层级分组生成嵌套树结构

本文介绍如何将 javascript 对象数组按指定属性顺序(如 ['a', 'b', 'c', 'd'])递归分组,构建符合图表库要求的嵌套树形结构(每个节点含 name 和可选 children),支持任意深度、自动去重与层级展开。

数据可视化场景中(如 ECharts 的 tree 或 sunburst 图),常需将扁平的对象数组转换为严格的层级嵌套结构。例如,给定一组具有相同属性键(A/B/C/D)的对象,需按属性值逐层聚类,形成 name + children 的递归树。核心挑战在于:既要保持属性顺序(A → B → C → D),又要正确合并共享前缀路径的节点,并将末级属性值作为叶子节点。

以下是一个健壮、可复用的实现方案:

function groupByKeys(data, keys) {
  // 步骤1:构建多层嵌套对象(键路径映射)
  const root = {};
  for (const item of data) {
    let node = root;
    for (const key of keys) {
      const value = item[key];
      // 使用 ??= 确保深层对象自动创建(ES2021+)
      node = (node[value] ??= {});
    }
  }

  // 步骤2:递归转换为目标树结构
  const buildTree = (obj) => {
    return Object.entries(obj).map(([name, child]) => {
      // 若 child 为空对象(即无子节点),则为叶子节点
      if (Object.keys(child).length === 0) {
        return { name: Number(name) }; // 自动转数字(适配示例中的数值)
      }
      // 否则递归构建 children
      return {
        name: Number(name),
        children: buildTree(child)
      };
    });
  };

  // 返回根节点(因 keys 非空,root 必有且仅有一个顶层 key)
  const result = buildTree(root);
  return result.length > 0 ? result[0] : {};
}

// ✅ 示例1:相同 A/B/C,不同 D → D 成为叶子
const data1 = [
  { A: 1, B: 5, C: 7, D: 67 },
  { A: 1, B: 5, C: 7, D: 69 }
];
console.log(groupByKeys(data1, ['A', 'B', 'C', 'D']));
// → { name: 1, children: [{ name: 5, children: [{ name: 7, children: [{ name: 67 }, { name: 69 }] }] }] }

// ✅ 示例2:C 值不同 → 分叉为两个同级节点
const data2 = [
  { A: 1, B: 5, C: 4, D: 67 },
  { A: 1, B: 5, C: 7, D: 69 }
];
console.log(groupByKeys(data2, ['A', 'B', 'C', 'D']));
// → { name: 1, children: [{ name: 5, children: [{ name: 4, children: [{ name: 67 }] }, { name: 7, children: [{ name: 69 }] }] }] }

关键设计说明:

  • 路径构建安全:使用 node[value] ??= {} 替代 node[value] || (node[value] = {}),避免 undefined 或 null 导致错误;
  • 类型一致性:Number(name) 统一将键名转为数字(因示例中所有值均为数值,若含字符串请移除此转换);
  • 空对象判据:Object.keys(child).length === 0 是判断叶子节点的可靠方式(比 !child 更精准);
  • 可扩展性:keys 参数支持任意长度和顺序(如 ['C', 'A']),无需修改逻辑;
  • 无副作用:纯函数式实现,不修改原始数据。

注意事项:

Getimg.ai
Getimg.ai

getimg.ai是一套神奇的ai工具。生成大规模的原始图像

下载

立即学习Java免费学习笔记(深入)”;

  • 若输入 data 为空数组,函数返回 {},建议调用前校验;
  • 属性值必须为可序列化为对象键的类型(推荐字符串/数字;Symbol 或对象会触发 toString() 导致意外行为);
  • 如需稳定排序(如数字升序),可在 Object.entries() 后添加 .sort((a, b) => Number(a[0]) - Number(b[0]));
  • 在旧版浏览器中,替换 ??= 为兼容写法:node[value] = node[value] || {}。

该方案兼顾简洁性与工程鲁棒性,可直接集成至数据预处理流程,高效支撑各类嵌套图表渲染需求。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
ECharts是什么
ECharts是什么

ECharts是基于JavaScript的开源可视化库,能够帮助开发者轻松地实现各种复杂的数据可视化效果,提供了丰富的图表类型和交互功能。本专题为大家提供ECharts是什么的相关的文章、下载、课程内容,供大家免费下载体验。

274

2023.08.04

echarts自适应大小设置
echarts自适应大小设置

使用ECharts的自适应大小设置可以使图表能够根据不同屏幕尺寸和设备进行自适应。一种是使用resize事件,在图表容器大小改变时重新渲染图表;另一种是使用CSS样式,通过设置图表容器的宽度和高度为百分比值,使图表容器根据父元素的大小进行自适应。根据实际需求选择合适的方法,可以使图表在不同设备上都能够良好地显示和交互 。

470

2023.09.13

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

243

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

641

2024.03.01

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

399

2023.09.04

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

444

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

213

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1518

2023.10.24

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

98

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号