- 背景:项目上需要对Echarts饼图进行功能定制,实现点击颜色块,下钻显示下一层级占比
- 说明:饼图实现点击下钻/面包屑返回的功能

- 数据结构
[{name: 'a',value: 1,children: [...]},...
]
this.myChart.on('click', (e) => {if (e.data?.children) {this.source = e.data.children this.breadcrumbList.push(e.data.name) }
})
<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) { 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;
},