echarts解决数据差异过大的问题

问题描述
使用echarts折线图和柱状图展示数据时,如果数据差异值较大,会导致显示图形差异过大,图表不美观。
如这一组数据[2000000, 200, 0.1, 20, 0, -10, -3000],渲染出来的效果如下图:
在这里插入图片描述
可以看到由于最大值和最小值差异过大,导致过小的值柱子显示不出来,数据的波动趋势不明显。
当前需要解决的问题是如何体现数据差异性,让小数值柱子也能显示出来。
解决方案:
使用对数轴(yAxis. type=“log”),适用于对数数据,可以解决数据差异过大的问题。但对数轴只适用于data>=0的情况。
如数据:barDatas = [2000000, 200, 0.1, 20, 3,3, 3000]
在这里插入图片描述
如果对数轴中的数组数据出现0或者负数情况,就会造成错误渲染。
在这里插入图片描述
试了很多办法都无法解决这个问题,最后采取了多个grid多轴的办法。

可以通过grid来划分多个网格区域,然后让正数和负数柱状图分别在在不同的区域展现。
如:const barDatas = [2000000, 200, 0.1, 20, 0, -10, -3000]
在这里插入图片描述
流程展示:

  • 将barDatas数组拆分为正数数组,负数数组

  • 设置三个grid,分别为用于展示正数,负数数据,以及底部X轴

  • 正负数数据网格区域y轴为yAxis. type=“log”,X轴网格区数数据区域yAxis. type=“value”

  • 正数柱状图series.data只展示大于0的数据,其余为null(barDatas.map(item => item > 0 ? item : null);
    负数柱状图series.data只展示小于0的数据,并展示为绝对值,其余为null(barDatas.map(item => item < 0 ? Math.abs(item): null)

  • 设置负数的y轴yAxis.inverse=true,让Y轴绕X轴上下翻转,并配置y轴标签显示yAxis.axisLabel.formatter=(val) => val === 1 ? 0 : -${val}

其中要解决的问题是:
1)解决起始0对齐的问题
在这里插入图片描述
因为对数轴的数据不能为0,所以需要设置上下yAxis的min为1,再通过yAxis.axisLabel.formatter将y轴的1改为0。
在这里插入图片描述
2)小于1的数据柱子无高度。
在这里插入图片描述
需要设置barMinHeight最小高度,同时改造小于1的数为1.01

这种方式能很好的解决数据差异过大的问题。
代码附上:

<!DOCTYPE html>
<html lang="en" style="height: 100%">

<head>
    <meta charset="utf-8">
</head>
<script type="text/javascript" src="https://registry.npmmirror.com/echarts/5.5.0/files/dist/echarts.min.js"></script>

<body style="height: 100%; margin: 0">
    <div id="container" style="width: 50%;height: 50%;border: 1px solid red;margin: 30px;"></div>
    <script type="text/javascript">
        var dom = document.getElementById('container');
        var myChart = echarts.init(dom, null, {
            renderer: 'canvas',
            useDirtyRect: false
        });
        var app = {};
        var option;
        // const barDatas = [1000000, 20000000, 0.1, 20, 0, -10, -3000];
        // const barDatas = [200000, -100];
        const barDatas = [2000000, 200, 0.1, 20, 0, -10, -3000]
        option = {
            color: ['#3398DB'],
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                    type: 'shadow'
                },
                formatter: (params) => {
                    const { dataIndex } = params[0]
                    return `${`城市${dataIndex + 1}`}${barDatas[dataIndex]}`
                }
            },
            grid: [{
                right: 20,
                left: 80,
                top: 30,
                bottom: '50%',
                containLabel: false,
            }, {
                right: 20,
                left: 80,
                top: '50%',
                bottom: 30,
                containLabel: false,
                show: false
            }, {
                right: 20,
                left: 80,
                top: '50%',
                bottom: 30,
                containLabel: false,
                show: false
            }],
            xAxis: [
                {
                    type: 'category',
                    gridIndex: 0,
                    show: false,
                },
                {
                    type: 'category',
                    show: false,
                    gridIndex: 1,
                },
                {
                    type: 'category',
                    interval: 0,
                    gridIndex: 2,
                    data: barDatas.map((item, index) => `城市${index + 1}`)
                },
            ],
            yAxis: [
                {
                    type: 'log',
                    gridIndex: 0,
                    min: 1, // 设置y轴最小值
                    axisLabel: {
                        formatter: (val) => val === 1 ? 0 : val
                    }
                },
                {
                    type: 'log',
                    gridIndex: 1,
                    inverse: true, //设置反向坐标,让Y轴绕X轴上下翻转
                    min: 1, // 设置y轴最小值
                    axisLabel: {
                        formatter: (val) => val === 1 ? 0 : `-${val}`
                    }
                },
                {
                    type: 'value',
                    gridIndex: 2,
                    show: false,
                },
            ],
            series: [
                {
                    name: '正数',
                    xAxisIndex: 0,
                    yAxisIndex: 0,
                    type: 'bar',
                    data: barDatas.map(item => item > 0 ? item > 1 ? item : 1.01 : null), // 正数柱状图series.data只展示大于0的数据
                    barMinHeight: 1.5,// 最小高度
                },
                {
                    name: '负数',
                    type: 'bar',
                    xAxisIndex: 1,
                    yAxisIndex: 1,
                    data: barDatas.map(item => item < 0 ? Math.abs(item) > 1 ? Math.abs(item) : 1.01 : null), // 负数柱状图eries.data只展示小于0的数据
                    barMinHeight: 1.5, // 最小高度
                },
                {
                    name: 'x轴',
                    xAxisIndex: 2,
                    yAxisIndex: 2,
                    type: 'bar',
                    show: false,
                    data: barDatas.map(item => null),
                },
            ],
        };
        if (option && typeof option === 'object') {
            myChart.setOption(option);
        }
        window.addEventListener('resize', myChart.resize);
    </script>
</body>

</html>

相关推荐

  1. 避免M取值引起数值问题

    2024-07-13 05:14:05       53 阅读
  2. Android Intent 传递数据问题

    2024-07-13 05:14:05       43 阅读
  3. 【Ubuntu 22.04】解决Ubuntu 22.04终端行距问题

    2024-07-13 05:14:05       52 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-13 05:14:05       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-13 05:14:05       71 阅读
  3. 在Django里面运行非项目文件

    2024-07-13 05:14:05       58 阅读
  4. Python语言-面向对象

    2024-07-13 05:14:05       69 阅读

热门阅读

  1. Linux学习笔记(三)文件权限

    2024-07-13 05:14:05       28 阅读
  2. 避免 WebSocket 连接被拒绝

    2024-07-13 05:14:05       24 阅读
  3. 小程序需要做等保测评吗?

    2024-07-13 05:14:05       20 阅读
  4. wireshark与tcpdump使用

    2024-07-13 05:14:05       21 阅读
  5. 韩国裸机云大宽带服务器主要特点和优势

    2024-07-13 05:14:05       25 阅读
  6. 【日常bug记录】el-checkbox 绑定对象数组

    2024-07-13 05:14:05       20 阅读
  7. UniVue@v1.3.0版本发布

    2024-07-13 05:14:05       27 阅读
  8. WXML,WXSS和HTML,CSS的区别

    2024-07-13 05:14:05       23 阅读
  9. ODrive学习笔记一:开发环境搭建

    2024-07-13 05:14:05       20 阅读
  10. Eureka 介绍与使用

    2024-07-13 05:14:05       26 阅读
  11. Perl基础入门指南:从零开始掌握Perl编程

    2024-07-13 05:14:05       30 阅读
  12. 认识string(二)详解

    2024-07-13 05:14:05       35 阅读
  13. Ubuntu下安装配置和调优Docker,支持IPV6

    2024-07-13 05:14:05       26 阅读
  14. Vue的生命周期函数有哪些?详细说明

    2024-07-13 05:14:05       26 阅读