实现ECharts双Y轴左右刻度线一致的例子


Posted in Python onMay 16, 2020

不一致的情况如下图:

实现ECharts双Y轴左右刻度线一致的例子

修改成一致的情况如下图:

实现ECharts双Y轴左右刻度线一致的例子

代码如下:

yAxis : [
          {
            type : 'value',
            name : '人数',
            //splitLine:{show:false},
            axisLabel : {
              formatter: '{value} 个',
              textStyle:{color: '#A23400'}//#A23400 purple
            },
            axisLine:{
               lineStyle:{color:'#A23400',width:'1'} //y轴坐标轴颜色 #A23400 black
            }
          },
          {
            type : 'value',
            name : '人次',
            //splitLine:{show:false},
            axisLabel : {
              formatter: qfamtter,
              textStyle:{color: '#00AEAE'}//#00AEAE blue
            },
            axisLine:{
               lineStyle:{color:'#00AEAE',width:'1'} //y轴坐标轴颜色 #00AEAE black
            },
            min: 0,
            max: Max2*2,
            splitNumber: 6,
            interval: (Max2*2 - 0) / 6
          }

其中需要加:

min: 0,
            max: Max2*2,
            splitNumber: 6,
            interval: (Max2*2 - 0) / 6

左边Y轴默认了分成6段,所以要把右边Y轴也分成6段。

附加:jquery 数组获取最大值和最值的方法,仅供参考

//计算最大值
 function cal_Max(a) {
    //debugger
    a=$.grep(a,function(n,i){return i>0;});
    var maxval = Math.max.apply(null, a);
    return maxval;
   }
 
 //计算最小值
 function calMin(a) {
  a=$.grep(a,function(n,i){return i>0;});
  var minval = Math.min.apply(null, a)
  return minval;
 }

补充知识:echarts 两个y轴展示折线图,并使两个y轴刻度线重合

效果如图:

实现ECharts双Y轴左右刻度线一致的例子

y轴刻度不重合情况:

实现ECharts双Y轴左右刻度线一致的例子

代码如下,具体的数据处理就不再一一展示,只看画图部分:

drawGraphChart() {
   // 具体的数据格式可以参考: https://echarts.baidu.com/examples/editor.html?c=multiple-y-axis
   // 处理两个y轴的最大值 => 为使两个y轴的标度线完全重合
   // 拿到左右两个y轴的最大数据之后 给他们分别取整成为最终 y轴上展示的值 也是为了能够确保两个值都能整除10
   const maxY1 = parseInt((Math.max(...maxData1) + 2000) / 1000) * 1000
   const maxY2 = parseInt((Math.max(...maxData2) + 10) / 10) * 10
   this.myChart = this.$echarts.init(document.getElementById('drawChart'))
   // var color = ['#d14a61', '#5793f3'], // 这个颜色和y轴的颜色对应,如果画的曲线较少,可以直接用两种颜色区分线是按照哪个坐标轴的刻度画的
   const option = {
    title: {
     left: 20,
     text: '趋势图'
    },
    xAxis: {
     type: 'category',
     // boundaryGap: false, // 数据完全填充x轴
     data: this.toRepeatTimeArr // x轴时间
    },
    legend: {
     type: 'scroll',
     right: 120,
     top: 0,
     left: '65%',
     bottom: 0,
     data: legendTankNum // 图例
    },
    grid: {
     left: '6%',
     right: '6%',
     top: '14%'
    },
    tooltip: {
     trigger: 'axis',
     axisPointer: {
      type: 'cross'
     }
    },
    yAxis: [
     {
      type: 'value',
      name: '体积',
      min: 0,
      max: maxY1, // 左侧y轴最大值
      // 两个y轴的刻度必须整除一个相同的数才能重合
      interval: Math.ceil(maxY1 / 10), // 间距等分为10等分 
      position: 'left', // y轴在左侧
      // y轴的颜色和按y轴刻度画的曲线的颜色
      // axisLine: {
      //  lineStyle: {
      //   color: color[0]
      //  }
      // },
      axisLabel: {
       formatter: '{value} L'
      }
     },
     {
      type: 'value',
      name: '温度',
      min: 0,
      max: maxY2, // 右侧y轴最大值
      interval: Math.ceil(maxY2 / 10), // 间距等分为10等分
      position: 'right', // y轴在右侧
      // axisLine: {
      //  lineStyle: {
      //   color: color[1]
      //  }
      // },
      axisLabel: {
       formatter: '{value} °C'
      }
     }
    ],
    toolbox: {
     right: 80,
     top: -5,
     feature: {
      saveAsImage: {}
     }
    },
    // {name: '--',type: 'line',data:[0,0,0···]}
    series: allRealData
   }
   // true 图数据不叠加
   this.myChart.setOption(option, true)
  }

以上这篇实现ECharts双Y轴左右刻度线一致的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中的map、reduce和filter浅析
Apr 26 Python
基于python实现的抓取腾讯视频所有电影的爬虫
Apr 22 Python
Python实现删除文件中含“指定内容”的行示例
Jun 09 Python
Python遍历某目录下的所有文件夹与文件路径
Mar 15 Python
Python全排列操作实例分析
Jul 24 Python
如何利用Boost.Python实现Python C/C++混合编程详解
Nov 08 Python
python版飞机大战代码分享
Nov 20 Python
python实现全盘扫描搜索功能的方法
Feb 14 Python
python之pyqt5通过按钮改变Label的背景颜色方法
Jun 13 Python
Python3将数据保存为txt文件的方法
Sep 12 Python
关于pytorch处理类别不平衡的问题
Dec 31 Python
详解Python+Selenium+ChromeDriver的配置和问题解决
Jan 19 Python
在echarts中图例legend和坐标系grid实现左右布局实例
May 16 #Python
Python如何使用PIL Image制作GIF图片
May 16 #Python
pyecharts调整图例与各板块的位置间距实例
May 16 #Python
通过Python实现一个简单的html页面
May 16 #Python
Python批量处理csv并保存过程解析
May 16 #Python
基于Python测试程序是否有错误
May 16 #Python
关于matplotlib-legend 位置属性 loc 使用说明
May 16 #Python
You might like
PHP 日期时间函数的高级应用技巧
2009/10/10 PHP
PHP+jQuery 注册模块的改进(三):更新到Smarty3.1
2014/10/14 PHP
HTML中嵌入PHP的简单方法
2016/02/16 PHP
PHP中抽象类和抽象方法概念与用法分析
2016/05/24 PHP
jquery中this的使用说明
2010/09/06 Javascript
JS 控制小数位数的实现代码
2011/08/02 Javascript
JS获得QQ号码的昵称,头像,生日的简单实例
2013/12/04 Javascript
js图片延迟技术一般的思路与示例
2014/03/20 Javascript
node.js使用require()函数加载模块
2014/11/26 Javascript
PageSwitch插件实现100种不同图片切换效果
2015/07/28 Javascript
关于JavaScript的变量的数据类型的判断方法
2015/08/14 Javascript
详解JavaScript正则表达式之分组匹配及反向引用
2016/03/09 Javascript
JavaScript必看小技巧(必看)
2016/06/07 Javascript
详解Node.js如何开发命令行工具
2016/08/14 Javascript
郁闷!ionic中获取ng-model绑定的值为undefined如何解决
2016/08/27 Javascript
Bootstrap整体框架之JavaScript插件架构
2016/12/15 Javascript
js实现产品缩略图效果
2017/03/10 Javascript
vue实现表格增删改查效果的实例代码
2017/07/18 Javascript
实例教学如何写vue插件
2017/11/30 Javascript
JQuery实现table中tr上移下移的示例(超简单)
2018/01/08 jQuery
浅谈vue项目如何打包扔向服务器
2018/05/08 Javascript
Node.js 使用request模块下载文件的实例
2018/09/05 Javascript
解读Python中degrees()方法的使用
2015/05/18 Python
python控制台中实现进度条功能
2015/11/10 Python
Python使用修饰器执行函数的参数检查功能示例
2017/09/26 Python
Python使用folium excel绘制point
2019/01/03 Python
Django中ORM外键和表的关系详解
2019/05/20 Python
关于Python3 类方法、静态方法新解
2019/08/30 Python
基于python的docx模块处理word和WPS的docx格式文件方式
2020/02/13 Python
Python利用Faiss库实现ANN近邻搜索的方法详解
2020/08/03 Python
Python通过类的组合模拟街道红绿灯
2020/09/16 Python
如何删除一个表里面的重复行
2013/07/13 面试题
Unix里面如何在后台运行程序
2016/10/14 面试题
字典算法实现及操作 --python(实用)
2021/03/31 Python
SpringBoot整合JWT的入门指南
2021/06/29 Java/Android
MYSQL 表的全面总结
2021/11/11 MySQL