网络编程
位置:首页>> 网络编程>> JavaScript>> echarts柱状堆叠图实现示例(图例和x轴都是动态的)

echarts柱状堆叠图实现示例(图例和x轴都是动态的)

作者:崽崽的谷雨  发布时间:2024-04-29 13:21:03 

标签:echarts,柱状,堆叠图

问题描述: 

 echarts柱状堆叠图,是很常用的图表,官网的例子很简单 。图例(legend),x轴(xAxis)都是写死的。但是一般实际应用中都是 动态的。下面就举个例子,实现图例和x轴都是动态的 柱状堆叠图。

echarts柱状堆叠图实现示例(图例和x轴都是动态的)

echarts 官网柱状 堆叠图 示例

 实现思路及步骤:

思路:通过官网的例子,我们能知道

  1.  xAxis 是一个数组 

  2.  series 是一个数组对象  其中name需要 对应着的是图例,有几个图例 series里就应该有几个项。需要把你的数据处理成 和例子数据结构一样的。

  3. stack 这个属性 很重要 Documentation - Apache ECharts stack API,官网的例子里 是三个柱状图并列。stack 相同的就会 堆叠在一起(stack 有几个他就会有几排并列,官网例子里有Ad,Search Engine他就有两个堆叠,去掉没有 stack属性的就能看到了)。

知道了这些就 很清晰了。

  • 第一步就是 遍历数据 ,找出 x轴的数据(切记要去重)

  • 遍历数据 生成 series

其实就是对数据的处理。 

示例:

 把这样的数据 做成堆叠图

let data = [
       { 日期: '2022-08-16', 要素名称: '空调液加注-正压压力', 报警总次数: 15 },
       { 日期: '2022-08-16', 要素名称: '空调液加注-正压检漏值', 报警总次数: 3 },
       { 日期: '2022-08-16', 要素名称: '刹车液加注-正压压力', 报警总次数: 5 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-二次抽真空值', 报警总次数: 6 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-二次抽真空时间', 报警总次数: 6 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-加注量', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '空调液加注-正压压力', 报警总次数: 45 }, ,
       { 日期: '2022-08-17', 要素名称: '刹车液加注-真空检漏值', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-含水量', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-真空检漏时间', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '空调液加注-二次抽真空值', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-正压压力', 报警总次数: 15 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-加注量', 报警总次数: 6 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-正压压力', 报警总次数: 23 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-正压检漏值', 报警总次数: 3 },
       { 日期: '2022-08-18', 要素名称: '空调液加注-加注量', 报警总次数: 3 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-精真空值', 报警总次数: 6 },
       { 日期: '2022-08-18', 要素名称: '空调液加注-正压压力', 报警总次数: 69 },
       { 日期: '2022-08-18', 要素名称: '空调液加注-正压检漏时间', 报警总次数: 3 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-含水量', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-正压压力', 报警总次数: 31 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-精真空值', 报警总次数: 12 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-正压压力', 报警总次数: 99 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-真空检漏值', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-正压检漏值', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-正压检漏时间', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-真空检漏值', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-加注量', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-含水量', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-正压检漏值', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-正压检漏时间', 报警总次数: 6 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-真空检漏时间', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '空调液加注-加注量', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-真空检漏值', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '空调液加注-正压检漏值', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '空调液加注-真空检漏值', 报警总次数: 15 },
   ];

echarts柱状堆叠图实现示例(图例和x轴都是动态的)

代码:

把该代码复制到 官网例子里 就能看到效果 。

let data = [
       { 日期: '2022-08-16', 要素名称: '空调液加注-正压压力', 报警总次数: 15 },
       { 日期: '2022-08-16', 要素名称: '空调液加注-正压检漏值', 报警总次数: 3 },
       { 日期: '2022-08-16', 要素名称: '刹车液加注-正压压力', 报警总次数: 5 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-二次抽真空值', 报警总次数: 6 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-二次抽真空时间', 报警总次数: 6 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-加注量', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '空调液加注-正压压力', 报警总次数: 45 }, ,
       { 日期: '2022-08-17', 要素名称: '刹车液加注-真空检漏值', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-含水量', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-真空检漏时间', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '空调液加注-二次抽真空值', 报警总次数: 3 },
       { 日期: '2022-08-17', 要素名称: '刹车液加注-正压压力', 报警总次数: 15 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-加注量', 报警总次数: 6 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-正压压力', 报警总次数: 23 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-正压检漏值', 报警总次数: 3 },
       { 日期: '2022-08-18', 要素名称: '空调液加注-加注量', 报警总次数: 3 },
       { 日期: '2022-08-18', 要素名称: '刹车液加注-精真空值', 报警总次数: 6 },
       { 日期: '2022-08-18', 要素名称: '空调液加注-正压压力', 报警总次数: 69 },
       { 日期: '2022-08-18', 要素名称: '空调液加注-正压检漏时间', 报警总次数: 3 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-含水量', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-正压压力', 报警总次数: 31 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-精真空值', 报警总次数: 12 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-正压压力', 报警总次数: 99 },
       { 日期: '2022-08-19', 要素名称: '刹车液加注-真空检漏值', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-正压检漏值', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-正压检漏时间', 报警总次数: 6 },
       { 日期: '2022-08-19', 要素名称: '空调液加注-真空检漏值', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-加注量', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-含水量', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-正压检漏值', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-正压检漏时间', 报警总次数: 6 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-真空检漏时间', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '空调液加注-加注量', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '刹车液加注-真空检漏值', 报警总次数: 9 },
       { 日期: '2022-08-20', 要素名称: '空调液加注-正压检漏值', 报警总次数: 12 },
       { 日期: '2022-08-20', 要素名称: '空调液加注-真空检漏值', 报警总次数: 15 },
   ];
   console.log(data)
   let date = []; //x轴日期
   let lenged = []; //series的个数
   let s = [];
   data.map((item) => {
       date.push(item["日期"]);
       lenged.push(item["要素名称"]);

});

date = [...new Set(date)]; //去重
   lenged = [...new Set(lenged)];
   console.log(date, lenged)
   let series = [];
   lenged.map((item) => { //生成  series
       let obj = {
           name: item,
           type: "bar",
           stack: "As",
           emphasis: {
               focus: 'series'
           },
           data: []
       };
       series.push(obj);
   });
   console.log(series)

data.map((item) => {//对series 的data进行处理

series.map((item1) => {

if (item1.name == item["要素名称"] && date.indexOf(item["日期"]) > -1) {
               item1.data[date.indexOf(item["日期"])] = item["报警总次数"]
           };
       })
   })

option = {
 tooltip: {
   trigger: 'axis',
   axisPointer: {
     type: 'shadow'
   }
 },
 legend: {},
 grid: {
   left: '3%',
   right: '4%',
   bottom: '3%',
   containLabel: true
 },
 xAxis: [
   {
     type: 'category',
     data: date
   }
 ],
 yAxis: [
   {
     type: 'value'
   }
 ],
 series: series
};

来源:https://blog.csdn.net/weixin_44058725/article/details/126588661

0
投稿

猜你喜欢

  • 一:关于MySQL5 MySQL5系列数据库是MySQL的最新版本的数据库,比较流行的发行版是mysql-5.0.18。MySQL 英文官方
  • 1.1 准备工作安装tableau安装MySQL数据库1.2 驱动包下载tableau连接MySQL数据库需要下载mysql对应的版本ODB
  • Python中赋值的含义在C++中,变量就是对象本身,对变量赋值就改变了它代表的对象。而在Python中,赋值的含义却是关联变量名字和实际对
  • 一、Pyecharts 概述Pyechart 是一个用于生成 Echarts 图表(Echarts 是基于 Javascript 的开源可视
  • 方式一:直接通过数据库厂商提供的相关驱动步骤导入相关驱动(Build Path)创建Driver类的实例化对象获取要连接数据库的URL创建P
  • 接着上一篇学习:https://www.jb51.net/article/70528.htm七、MySQL数据库Schema设计的性能优化高
  • 说到这个问题,基本上有人就会想到三个问题:1,什么是系统数据?2,为什么要移动系统数据库?3,移动系统数据库我们可以用附加和分离,为什么还要
  • 本文实例分析了python开发之str.format()用法。分享给大家供大家参考,具体如下:格式化一个字符串的输出结果,我们在很多地方都可
  • 背景今天在工作中,同事遇到一个上传图片的问题:系统要求的图片大小不能超过512KB。但是同事又有很多照片。这要是每一个照片都用ps压缩的话,
  • 随着CSS 框架的流行升温不断,前端er们也越来越关注CSS框架的使用,国内也有很多关于各种CSS框架的使用技巧和教程,彬Go一直关注着各种
  • 引言 上一篇介绍完了观察者模式的原理,本篇想就此再介绍一个小应用,虽然我也就玩了一下午,是当时看observer正好找到的,以及还有Djan
  • 前言最近学习scrapy爬虫框架,在使用pycharm安装scrapy类库及创建scrapy项目时花费了好长的时间,遇到各种坑,根据网上的各
  • 怎样解决MySQL 5 0 16的乱码问题? 本文给出了解决方法:问:怎样解决MySQL 5.0.16的乱码问题?答:MySQL 5.0.1
  • 最近github上开源了一个"新语言"vlang,火的不得了,我不信,于是乎,尝试了一下,真香。以下内存均来自https
  • mark 一下使用 bootstrap selectpicker 遇到的一个小issue,作为下次查错使用$('.selectpic
  • 很多人都使用很多的编程工具,尤其对于Web开发人员。这个小教程将告诉各位如何使DreamweaverMX编程环境适合中国的Web开发人员。一
  • 每天都要记得健康打卡尊敬的老师,我忘了这次的健康打卡,反思的时候我想了很多东西,反省了很多事情,自己也很懊悔,触犯了学校的规定,深刻认识到自
  • 前言可扩展标记语言,是一种简单的数据存储语言,XML被设计用来传输和存储数据存储,可用来存放配置文件,例:java配置文件传输,网络传输以这
  • 给定损失函数的输入y,pred,shape均为bxc。若设定loss_fn = torch.nn.MSELoss(reduction=
  • 目录支持多种类型的过滤避免多个范围查询优化排序理解索引概念最简单的方式是通过一个案例来进行,以下就是这样的一个案例。假设我们需要设计一个在线
手机版 网络编程 asp之家 www.aspxhome.com