基于 v-charts 封装双向条形图

咱们先来看实现效果
image.pnghtml

以这张图来举例
经过从新封装能够实现双向条形图的显示
既能够横向比较同一天的收入支出状况
也能够竖向比较不一样日期的收入/支出状况echarts

咱们先来准备数据源:this

{
      columns: ["日期", "收入", "支出"],
      rows: [
        {
          日期: "8/7",
          收入: -233,
          支出: 120
        },
        {
          日期: "8/5",
          收入: -322,
          支出:450
        },
        {
          日期: "7/4",
          收入: -432,
          支出: 430
        },
        {
          日期: "10/4",
          收入: -233,
          支出: 210
        }
      ]
    };

注意这里必定要把其中一项的值设置为负数,不然没法显示到左边一栏spa

设置完数据咱们能够先看一眼效果:
image.png
初步实现条形图一左一右的效果code

那如何实现同一维度的两个指标在同一行显示?
咱们在配置属性中加上这么一个属性
"stack"orm

this.chartSettings = {
      stack: {
        xxx: [`收入`, `支出`]
      }
    };

查看官方文档,咱们来理解一下这个属性htm

series[i]-bar.stack string
数据堆叠,同个类目轴上系列配置相同的stack值能够堆叠放置。

也就是说,设置了这个属性,咱们能够让两个条形图合并为一个
若是不考虑正负问题,堆叠便可实现下面这个效果
image.png
感兴趣的能够去官方看一下在线运行的演示效果
https://www.echartsjs.com/examples/zh/editor.html?c=bar-negativeblog

设置完这个属性咱们来看一下效果
image.png
能够看到同一日期的收入支出状况已经在一行显示了文档

最后咱们来解决坐标轴及图形标签值显示为负数的问题
咱们能够在 chartsetting 属性中修改 label 的 formatter 属性
自定义标签的文字
根据咱们的需求,经过 Math.abs()的方法,以绝对值的形式显示get

this.chartSettings = {
      label: {
        normal: {
          show: true,
          formatter: params => {
            return `${params.seriesName}:${Math.abs(params.value)}`;
          }
        }
      }
    };

坐标轴数值修改也是一个道理

afterConfig(options) {
      options.xAxis[0].axisLabel = {
        formatter: function(value) {
          return  Math.abs(value);
        } //显示的数值都取绝对值
      };
      return options;
    },

这样就能够实现咱们的最终效果了
image.png

相关文章
相关标签/搜索