基於 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

相關文章
相關標籤/搜索