echarts 堆叠柱状图 点击图例label动态显示总和

1. 问题呈现

场景描述:上图是一个实现的堆叠柱状图,测试发现点击图例时,存在以下问题:

1)因为label放在最后一类用formatter函数处理作为数据总和展示,所以当取消最后一类对应的图例时,它的label也会一起隐藏,页面上数据总和消失。

css 复制代码
series: [
  {...},
  {...},
  {
    type: 'bar',
    data: lowCount,
    name: '低危',
    stack: '总和',
    itemStyle: { color: '#91cc75' },
    label: {
      show: true,
      position: 'top',
      color: '#57606f',
      fontWeight: 'bold',
      formatter: function(params) {
        return dataValueList[params.dataIndex]; // dataValueList 固定的每列总和数组
      }
    }
  }
]

2)因为数据总和不是动态计算的,所以当取消有数据的图例时,左侧刻度轴和柱状图发生变化,但页面上展示的是每列全部数据总和,而不是剩余图例的列数据总和。

2. 实现动态显示

思路 :绑定echats的图例的legendselectchanged事件,每次图例change都重新计算数据的总和。

kotlin 复制代码
const option = { ...... };

// 获取配置中的series数组
var series = option["series"];
// 第一次使用
var fun = function (params) {
  var datavalue = 0;
  for (var i = 0; i < series.length; i++) { 
    datavalue += series[i].data[params.dataIndex];
  }
  // 返回总数
  return datavalue; 
}
// 赋值最后一项的formatter
series[series.length - 1]["label"]["formatter"] = fun;

myChart.setOption(option);

除了动态计算每一列数据总和,还需要注意其它更改。因为上述问题中取消最后一类图例时导致label消失,所以初始需要给每一类对象都加上label,控制label的显隐来在效果上实现需求。

1)series数组中的每一项都要添加label。默认给最上层的数据label的show为true,其他为false(如果没有初始值,后面点击图例时label更新不上)。

2)通过legendselectchanged事件,可以监听到图例变化时已勾选的图例list,利用已勾选的图例,判断哪一类数据需要展示label,哪些不展示label。

3)legendselectchanged事件处理数据之后,重新setOption,更新视图。

ini 复制代码
// 监听图例点击事件
myChart.on('legendselectchanged', function(obj) {
  // 获取点击的对象
  console.log('obj.selected', obj);
  var selObj = obj.selected;
  var selArr = [];
  for (var key in selObj) {
    if (selObj[key]) {
      for (var i = 0, l = series.length; i < l; i++) {
        var changename = series[i]['name'];
        if (changename == key) {
          selArr.push(i);
        }
      }
    }
  }
  console.log('selObj----selArr', selObj, selArr);
  
  // 动态计算剩余图例的列数据总和
  var fun = function(params) {
    var datavalue = 0;
    // 与name数组对比,相等则相加
    for (let i = 0; i < selArr.length; i++) {
      for (let j = 0; j < series.length; j++) {
        if (selArr[i] == j) {
          datavalue += series[j].data[params.dataIndex];
        }
      }
    }
    return datavalue;
  };

  // 先把每一项的label置为 fales
  for (let j = 0; j < series.length; j++) {
    series[j]['label']['show'] = false;
  }
  // 动态选取最上层那一项展示label,其它不展示,解决只有最后一项有label取消了label消失问题
  for (let k = series.length - 1; k >= 0; k--) {
    var name = series[k]['name'];
    console.log('----name', name);
    if (obj['selected'][name]) {
      series[k]['label']['formatter'] = fun;
      series[k]['label']['show'] = true;
      break;
    }
  }
  // this.$nextTick(() => {
  //   myChart.setOption(option);
  // });
  myChart.setOption(option);
});

实现效果展示:

3. 学习地址

www.jianshu.com/p/275747429...
blog.csdn.net/agua001/art...

相关推荐
veneno11 小时前
大量异步并发请求控制并发解决方案
前端
i***t91911 小时前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端
oden11 小时前
2025博客框架选择指南:Hugo、Astro、Hexo该选哪个?
前端·html
小光学长11 小时前
基于ssm的宠物交易系统的设计与实现850mb48h(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·前端·数据库
云中飞鸿11 小时前
函数:委托
javascript
小小前端要继续努力12 小时前
渐进增强、优雅降级及现代Web开发技术详解
前端
老前端的功夫12 小时前
前端技术选型的理性之道:构建可量化的ROI评估模型
前端·javascript·人工智能·ubuntu·前端框架
狮子座的男孩13 小时前
js函数高级:04、详解执行上下文与执行上下文栈(变量提升与函数提升、执行上下文、执行上下文栈)及相关面试题
前端·javascript·经验分享·变量提升与函数提升·执行上下文·执行上下文栈·相关面试题
爱学习的程序媛13 小时前
《JavaScript权威指南》核心知识点梳理
开发语言·前端·javascript·ecmascript
乐观主义现代人13 小时前
go 面试
java·前端·javascript