当前位置: 首页 > news >正文

ECharts饼图下钻

  • 背景:项目上需要对Echarts饼图进行功能定制,实现点击颜色块,下钻显示下一层级占比
  • 说明:饼图实现点击下钻/面包屑返回的功能
    在这里插入图片描述
  • 数据结构
[{name: 'a',value: 1,children: [...]},...
]
  • 点击下钻
// 为图表绑定点击事件(需要在destroy前进行事件解绑)
this.myChart.on('click', (e) => {if (e.data?.children) {this.source = e.data.children // 将子级用于当前图表显示this.breadcrumbList.push(e.data.name) // 面包屑添加子级名称}
})
  • 面包屑返回
<!-- 面包屑-显示下钻层级及点击返回 数据结构: [xxx, xxx, ...] -->
<row class="breadcrumb" v-if="drillAble"><spanclass="clickable flex"v-for="(item, index) in breadcrumbList":key="index"@click="handleCrumbClick(index)"><OverflowTip style="max-width: 200px" :content="item">{{ item }}</OverflowTip><span class="px-5" v-if="index < breadcrumbList.length - 1"> / </span></span>
</row>
handleCrumbClick(index) { // index为点击面包屑的层级if (index === this.breadcrumbList.length - 1) return // 点击当前层级 不做任何操作this.breadcrumbList.splice(index + 1) // 删除下级面包屑if (index === 0) {this.source = this.originData // 根级别 直接赋值} else {const parentName = this.breadcrumbList[index]const parentData = this.findParentData(this.originData, parentName) // 递归查找this.source = parentData?.children || []}
},
findParentData(data, name) {for (const item of data) {if (item.name === name) {return item; // 找到对应的父级节点}if (item.children) {const result = this.findParentData(item.children, name);if (result) {return result; // 在子级中递归查找}}}return null; // 如果没有找到
},
http://www.lryc.cn/news/516969.html

相关文章:

  • 【RK3568笔记】Android修改开机动画
  • 嵌入式技术之Linux(Ubuntu) 一
  • 代码随想录day39 动态规划7
  • ESP32-S3模组上实现低功耗(5)
  • PDF转文本以及转图片:itextpdf
  • AnaConda下载PyTorch慢的解决办法
  • 移动端自动化测试Appium-java
  • IO: 作业:Day1
  • ue5 替换角色的骨骼网格体和动画蓝图
  • el-cascader 树状选择-点击父级禁用子级
  • AWS re:Invent 的创新技术
  • PHP7和PHP8的最佳实践
  • Debian、Ubuntu 22.04和ubuntu 24.04国内镜像源(包括 docker 源)
  • 点亮一个esp32 的led
  • C++ shared_ptr进一步认知,为什么引用计数>2退出作用域都可以调用析构
  • JavaScript代码片段二
  • 【计算机视觉】单目深度估计模型-Depth Anything-V2
  • Servlet 和 Spring MVC:区别与联系
  • 【期末复习】三、内存管理
  • Microsoft Azure Cosmos DB:全球分布式、多模型数据库服务
  • 【Docker】安装registry本地镜像库,开启Https功能
  • JUC--线程池
  • 后端Java开发:第十一天
  • 基于 GEE 的长时间序列 Landsat 5 影像下载
  • Unity-Mirror网络框架从入门到精通之Attributes属性介绍
  • 软考证书邮寄步骤
  • 计算机网络 (29)网络地址转换NAT
  • nlp培训重点-2
  • 设计模式(1)——面向对象和面向过程,封装、继承和多态
  • 培训机构Day24