Echarts双向柱形图

样式图:

代码:

<template>
  <div id="lineChart" style="width:100%;height:100%;"></div>
</template>
<script>
export default {
  name: "LineChart",
  data() {
    return {};
  },
  mounted() {
    this.drawChart();
  },
  methods: {
    async drawChart() {
      const xData = ['建筑石用材', '电(热)能', '矿石', '其他']
      const lastYearData = [88, 59, 32, 15];
      const thisYearData = [99.45, 72.69, 53.46, 30.22];
      const timeLineData = [1];
      let textColor = "#fff";
      let lineColor="rgba(255,255,255,0.2)";
      let colors = [{
          borderColor: "rgba(2, 191, 232,1)",
          start: "rgba(2, 191, 232,0.8)",
          end: "rgba(2, 191, 232,0.1)"
        },
        {
          borderColor: "rgba(1, 231, 152,1)",
          start: "rgba(1, 231, 152,0.1)",
          end: "rgba(1, 231, 152,0.8)"
        },
      ];
      // 基于准备好的dom,初始化echarts实例
      const myLineChart = this.$echarts.init(
        document.getElementById("lineChart")
      );
      // 指定图表的配置项和数据
      const option = {
        baseOption: {
          // backgroundColor: background,
          timeline: {
            show: false,
            top: 0,
            data: []
          },
          grid: [
            {
              show: false,
              left: '12%',
              top: '0%',
              bottom: '0%',
              containLabel: true,
              width: '28%'
            },
            {
              show: false,
              left: '52.5%',
              top: '0%',
              bottom: '18%',
              width: '0%'
            },
            {
              show: false,
              right: '12%',
              top: '0%',
              bottom: '0%',
              containLabel: true,
              width: '28%'
            }
          ],
          xAxis: [
            {
              type: 'value',
              inverse: true, // 强制设置坐标轴分割间隔
              axisLine: { // 坐标轴轴线相关设置
                show: true, // 是否显示坐标轴轴线
                onZero: true, // X 轴或者 Y 轴的轴线是否在另一个轴的 0 刻度上
                lineStyle: {
                  color: '#00A5CA45'
                }
              },
              axisTick: {
                show: true
              },
              position: 'bottom',
              axisLabel: {
                show: true,
                color: '#c6d3d7',
                fontSize: 12,
                fontFamily: "DINPro-Regular"
              },
              splitLine:{
                show: false
              },
            },
            {
              gridIndex: 1,
              show: false
            },
            {
              gridIndex: 2,
              axisLine: {
                show: true, // 是否显示坐标轴轴线
                onZero: true, // X 轴或者 Y 轴的轴线是否在另一个轴的 0 刻度上
                lineStyle: {
                  color: 'rgba(1, 231, 152, 0.3)'
                }
              },
              axisTick: {
                show: true
              },
              position: 'bottom',
              axisLabel: {
                show: true,
                color: '#c6d3d7',
                fontSize: 12,
                fontFamily: "DINPro-Regular"
              },
              splitLine: {
                show: false
              },
            }
          ],
          yAxis: [
            {
              type: 'category',
              inverse: true,
              position: 'right',
              axisLine: {
                show: true,
                lineStyle:{
                  color: '#00A5CA45'
                }
              },
              axisTick: {
                show: false
              },
              axisLabel: {
                show: false
              },
              data: xData
            },
            {
              gridIndex: 1,
              type: 'category',
              inverse: true,
              position: 'left',
              axisLine: {
                show: false
              },
              axisTick: {
                show: false
              },
              axisLabel: {
                show: true,
                // padding:[-5,0,20,0],
                textStyle: {
                  color: '#c1cbcc',
                  fontSize: 12,
                  fontFamily: "pmzd_title"
                },
                align: "center"
              },
              data: xData.map(function(value) {
                return {
                  value: value,
                  textStyle: {
                    align: 'center'
                  }
                }
              })
            },
            {
              gridIndex: 2,
              type: 'category',
              inverse: true,
              position: 'left',
              axisLine: {
                show: true,
                lineStyle:{
                  color:lineColor
                }
              },
              axisTick: {
                show: false
              },
              axisLabel: {
                show: false
              },
              data: xData
            }
          ],
          series: []
        },
        options: []
      }
      option.baseOption.timeline.data.push(timeLineData[0])
      option.options.push({
      series: [
        {
          name: "2017",
          type: "bar",
          itemStyle: {
            normal: {
              label: {
                show: true, //开启显示
                position: 'left', //在上方显示
                textStyle: { //数值样式
                  color: colors[0].borderColor,
                  fontSize: 12
                }
              },
              color: new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [{
                  offset: 0,
                  color: colors[0].start
                },
                {
                  offset: 1,
                  color: colors[0].end
                }
              ]),
              borderColor: new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [{
                  offset: 0,
                  color: colors[0].borderColor
                },
                {
                  offset: 1,
                  color: colors[0].end
                }
              ]),
              borderWidth: 1
            }
          },
          data: lastYearData,
            animationEasing: "elasticOut"
        },
        {
            name: "2018",
            type: "bar",
            // stack: "2",
            // barWidth: 25,
            xAxisIndex: 2,
            yAxisIndex: 2,
            itemStyle: {
              normal: {
                label: {
                  show: true, //开启显示
                  position: 'right', //在上方显示
                  textStyle: { //数值样式
                    color: colors[1].borderColor,
                    fontSize: 12
                  }
                },
                color: new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [{
                    offset: 0,
                    color: colors[1].start
                  },
                  {
                    offset: 1,
                    color: colors[1].end
                  }
                ]),
                borderColor: new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [{
                    offset: 0,
                    color: colors[1].start
                  },
                  {
                    offset: 1,
                    color: colors[1].borderColor
                  }
                ]),
                borderWidth: 1
              }
            },
            data: thisYearData,
            animationEasing: "elasticOut"
        }
      ]
    });
      // 使用刚指定的配置项和数据显示图表。
      myLineChart.setOption(option);
    }
  },
};
</script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值