0

0

ECharts 实现垂直排列且横向连接的树图(Treemap)布局方案

霞舞

霞舞

发布时间:2026-02-23 18:44:01

|

289人浏览过

|

来源于php中文网

原创

ECharts 实现垂直排列且横向连接的树图(Treemap)布局方案

echarts 原生 treemap 不支持严格的垂直流式布局与跨系列连接,但可通过多实例 treemap 手动定位+统一样式模拟实现类“垂直堆叠+水平对齐”的视觉效果。

echarts 原生 treemap 不支持严格的垂直流式布局与跨系列连接,但可通过多实例 treemap 手动定位+统一样式模拟实现类“垂直堆叠+水平对齐”的视觉效果。

在数据可视化中,当需要将多个分类(如不同业务模块、部门或时间周期)以垂直方向依次排列、横向对齐、尺寸按值比例缩放的方式呈现时,开发者常期望 Treemap 能像瀑布流或分栏布局一样可控排布。然而,ECharts 的 series-treemap 类型采用自适应矩形填充算法(基于 squarified 算法),其节点顺序与空间分配由 squareRatio、leafDepth 和数据结构共同决定,无法通过配置直接实现跨 series 的垂直流式连接布局

官方文档中 squareRatio 参数虽可影响单个 Treemap 内部矩形的宽高倾向(例如设为较大值促使更“竖直”的子块),但它仅作用于单个系列内部,并不能协调多个 series 之间的相对位置或对齐关系。因此,若需达成类似下图所示的“垂直分列、左对齐、宽度按类别独立缩放”的效果(即每个 category 占一竖列,内部节点从上到下垂直堆叠,各列之间无缝/紧凑衔接),推荐采用以下多 Treemap 实例 + 精确坐标控制的工程化方案:

腾讯智影-AI数字人
腾讯智影-AI数字人

基于AI数字人能力,实现7*24小时AI数字人直播带货,低成本实现直播业务快速增增,全天智能在线直播

下载

✅ 核心思路:拆分 + 定位 + 视觉统一

  • 将原始层级数据按顶级分类(如 A/B/C/D)拆分为多个独立 treemap series;
  • 使用 left 和 width 显式控制每个 Treemap 在画布中的水平位置与宽度;
  • 设置 roam: false 和 nodeClick: false 禁用交互,避免干扰视觉连贯性;
  • 统一 levels 配置(尤其 gapWidth、color)确保风格一致;
  • 所有 Treemap 共享相同高度(默认填满容器),形成自然的垂直对齐。

? 示例代码(可直接运行)

option = {
  tooltip: {
    trigger: 'item',
    formatter: '{b}: {c} KB'
  },
  series: [
    // Category A — 左侧第一列
    {
      type: 'treemap',
      name: 'CATEGORY A',
      width: '23%',
      left: '4%',
      height: '100%', // 确保撑满容器高度
      roam: false,
      nodeClick: false,
      label: { show: true, formatter: '{b}' },
      itemStyle: { borderColor: '#fff', borderWidth: 1 },
      levels: [{
        color: ['#4A90E2'],
        itemStyle: { gapWidth: 4 }
      }],
      data: [
        { name: 'A1', value: 40 },
        { name: 'A2', value: 6 },
        { name: 'A3', value: 24 },
        { name: 'A4', value: 15 },
        { name: 'A5', value: 12 },
        { name: 'A6', value: 4 },
        { name: 'A7', value: 18 }
      ]
    },
    // Category B — 第二列
    {
      type: 'treemap',
      name: 'CATEGORY B',
      width: '23%',
      left: '30%',
      roam: false,
      nodeClick: false,
      label: { show: true, formatter: '{b}' },
      itemStyle: { borderColor: '#fff', borderWidth: 1 },
      levels: [{
        color: ['#50C878'],
        itemStyle: { gapWidth: 4 }
      }],
      data: [
        { name: 'B1', value: 13 },
        { name: 'B2', value: 17 },
        { name: 'B3', value: 8 },
        { name: 'B4', value: 24 },
        { name: 'B5', value: 15 },
        { name: 'B6', value: 10 },
        { name: 'B7', value: 24 }
      ]
    },
    // Category C — 第三列
    {
      type: 'treemap',
      name: 'CATEGORY C',
      width: '23%',
      left: '56%',
      roam: false,
      nodeClick: false,
      label: { show: true, formatter: '{b}' },
      itemStyle: { borderColor: '#fff', borderWidth: 1 },
      levels: [{
        color: ['#2E8B57'],
        itemStyle: { gapWidth: 4 }
      }],
      data: [
        { name: 'C1', value: 4 },
        { name: 'C2', value: 20 },
        { name: 'C3', value: 6 },
        { name: 'C4', value: 18 },
        { name: 'C5', value: 22 },
        { name: 'C6', value: 35 }
      ]
    },
    // Category D — 右侧较窄列
    {
      type: 'treemap',
      name: 'CATEGORY D',
      width: '16%',
      left: '82%',
      roam: false,
      nodeClick: false,
      label: { show: true, formatter: '{b}' },
      itemStyle: { borderColor: '#fff', borderWidth: 1 },
      levels: [{
        color: ['#FF8C00'],
        itemStyle: { gapWidth: 4 }
      }],
      data: [
        { name: 'D1', value: 7 },
        { name: 'D2', value: 19 },
        { name: 'D3', value: 12 },
        { name: 'D4', value: 11 },
        { name: 'D5', value: 4 },
        { name: 'D6', value: 9 }
      ]
    }
  ]
};

⚠️ 注意事项与优化建议

  • 响应式适配:left 和 width 建议使用百分比(如 '30%')而非像素值,配合容器 resize() 保证图表缩放时布局稳定;
  • 间隙控制:所有 Treemap 的 gapWidth 应保持一致(如 4),避免列间出现不协调的空白;
  • 颜色管理:为每个 category 指定明确色系(如蓝/绿/橙),增强可读性;若需渐变,可在 levels[0].color 中传入数组;
  • 性能考量:每个 Treemap 实例均独立渲染,系列过多(>6)可能影响性能,建议结合 visibleMin 过滤微小节点;
  • 替代方案提示:如需真正支持拖拽、缩放、联动下钻等高级交互,可考虑封装为自定义组件,或改用 grid + bar / custom 系列模拟 Treemap 视觉逻辑。

该方案虽非 ECharts 原生 Treemap 的“开箱即用”特性,但凭借配置的确定性与视觉的高度可控性,已成为企业级仪表盘中实现定制化层级布局的成熟实践路径。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ECharts是什么
ECharts是什么

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

275

2023.08.04

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

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

474

2023.09.13

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

544

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

27

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

39

2026.01.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

422

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

595

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

467

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1127

2026.02.13

热门下载

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

精品课程

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

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