背景
项目上需要对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">
<span
class="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; // 如果没有找到
},