Echart以特定方式配置饼图例

use*_*845 2 javascript pie-chart reactjs echarts

我想以不同的格式显示饼图例及其值。我正在附上图像。我正在寻找它,但到目前为止还没有找到如何做到这一点。如果您看到图像,则会显示图例及其对应的值,我无法复制。

派传奇

Ser*_*rov 5

您想显示值而不是百分比吗?如果是,那么这是需要做的一些工作,因为默认情况下图例组件不知道数据的其他维度。尝试从以下代码开始:

var option = {
  //...
  legend: {
    formatter: name => {
      var series = myChart.getOption().series[0];
      var value = series.data.filter(row => row.name === name)[0].value
      return name + '    ' + value;
    },
  }
}
Run Code Online (Sandbox Code Playgroud)

  var myChart = echarts.init(document.getElementById('main'));
  var option = {
    tooltip: {
        trigger: 'item',
        formatter: '{a} <br/>{b}: {c} ({d}%)'
    },
    legend: {
        orient: 'vertical',
        left: 10,
        data: ['Category1', 'Category2', 'Category3', 'Category4', 'Category5'],
        formatter: (name) => {
	        var series = myChart.getOption().series[0];
      		var value = series.data.filter(row => row.name === name)[0].value;
      		return name + '    ' + value;
        },
    },
    series: [
        {
            name: 'Series',
            type: 'pie',
            label: { show: false },
            labelLine: { show: false },
            data: [
                {value: 335,  name: 'Category1'},
                {value: 310,  name: 'Category2'},
                {value: 234,  name: 'Category3'},
                {value: 135,  name: 'Category4'},
                {value: 1548, name: 'Category5'}
            ]
        }
    ]
};


myChart.setOption(option);
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdn.jsdelivr.net/npm/echarts@4.7.0/dist/echarts.min.js"></script>
<div id="main" style="width: 600px;height:400px;"></div>
Run Code Online (Sandbox Code Playgroud)