vue+echarts实现条纹柱状横向图

本文实例为大家分享了vue+echarts实现条纹柱状横向图的具体代码,供大家参考,具体内容如下

实现效果:

<template>
  <div id="BusinessTop5Chart" style="flex: 1; height: 300px; width: 614px; margin-left: 10px"></div>
</template>
<script>
import { getNoteMatters } from '@/api/government';
const colors = [
   'rgba(248, 75, 110, 1)',
   'rgba(239, 142, 47, 1)',
   'rgba(234, 202, 4, 1)',
   'rgba(79, 224, 255, 1)',
   'rgba(106, 196, 255, 1)',
 ];
export default {
  data() {
    return {
      list: [],
      list1: [],
      list2: [],
      Top5ListName: [],
      Top5ListValue:[]
    };
  },
  mounted() {
    this.getNoteMatters();
  },
  methods: {
    initMap() {
      var myChart = this.$echarts.init(document.getElementById('BusinessTop5Chart'));
      const option = {
        grid: {
          top: 20,
          bottom: 30,
          left: 10,
          right: 150,
          containLabel: true,
        },
        tooltip: {
          show: true,
          trigger: 'axis',
          axisPointer: {
            type: 'shadow',
          },
        },
        xAxis: {
          type: 'value',
          splitLine: {
            show: false,
          },
          axisLine: {
            show: false,
          },
          axisLabel: {
            show: false,
          },
          axisTick: {
            show: false,
          },
          position: 'top',
        },
        yAxis: {
          type: 'category',
          data: this.Top5ListName,
          inverse: true, //倒叙
          axisLine: {
            show: false,
          },
          axisTick: {
            show: false,
          },
          axisLabel: {
            textStyle: {
              color: 'rgba(255,255,255,0.85)',
              fontSize: 14,
              fontFamily: 'TencentSans',
            },
            padding: [0, 0, 20, 0],
            inside: true,
            verticalAlign: 'bottom',
          },
        },
        series: [
          {
            type: 'bar',
            barGap: '-90%',
            barMaxWidth: 14,
            z: 0,
            label: {
              normal: {
                show: false,
                position: 'right',
                fontSize: 14,
                offset: [16, 0],
              },
            },
            data: this.list,
          },
          {
            type: 'bar',
            barGap: '-90%',
            barMaxWidth: 14,
            itemStyle: {
              color: 'rgba(26, 49, 99, 0.5)',
            },
            tooltip: {
              show: false,
            },
            data: this.list1,
          },
          {
            type: 'pictorialBar',
            symbolRepeat: 'fixed',
            symbolMargin: 4,
            symbol: 'rect',
            symbolClip: true,
            symbolSize: [1, 14],
            symbolPosition: 'start',
            itemStyle: {
              color: 'rgba(0,0,0,1)',
            },
            data: this.list2,
          },
        ],
      };
      myChart.setOption(option);
    },
    getNoteMatters() {
      getNoteMatters().then((res) => {
        const { status, data } = res;
        const { businessTpo5 } = JSON.parse(data);
        if (status === 200) {
        // this.Top5ListName=[
        //      {0: "三亚市税务局", 
        //       1: "三亚市市场监督管理局", 
        //       2: "三亚市公安局", 
        //       3: "三亚市邮政管理局", 
        //       4: "三亚市社会保险服务中心窗口"}]
          this.Top5ListName = businessTpo5.map((item) => {
            return item.agencies;
          });
        // this.Top5ListValue=[{0: 189354, 1: 56933, 2: 13267, 3: 10979, 4: 9054}]
          this.Top5ListValue = businessTpo5.map((item) => {
            return Number(item.num);
          });
          const max = Math.max.apply(null, this.Top5ListValue);
       // this.list=[{itemStyle:
       //         color: "rgba(248, 75, 110, 1)"
       //         name: "三亚市税务局"
       //         num: "189354"
       //         rate: "57.03%"
       //         value: 189354}]
          this.list = businessTpo5.map((item, index) => {
            let obj = {
              name: item.agencies,
              value: Number(item.num),
              num: item.num,
              rate: item.rate,
              itemStyle: {
                color: colors[index],
              },
            };
            return obj;
          });
       // this.list1=[
       // label:{
       // normal:{
       // color: colors[index],
       // fontSize: 14
       // position: "right"
       // show: true
       // offset:[16,0]
       // name: "三亚市税务局"
       // formatter(){return(item.num+'单位'+''+item.rate)}
       // rate: "57.03%"
       // value: 189354}}
          this.list1 = businessTpo5.map((item, index) => {
            let obj = {
              name: item.agencies,
              value: max,
              label: item.num,
              rate: item.rate,
              label: {
                normal: {
                  show: true,
                  position: 'right',
                  fontSize: 14,
                  color: colors[index],
                  offset: [16, 0],
                  formatter() {
                    return (
                      item.num + '件' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + item.rate
                    );
                  },
                },
              },
            };
            return obj;
          });
      // this.list2=[{label: "189354"
      // name: "三亚市税务局"
      // rate: "57.03%"
      // value: 189354}]    
        this.list2 = businessTpo5.map((item) => {
            let obj = {
              name: item.agencies,
              value: Number(item.num),
              label: item.num,
              rate: item.rate,
            };
            return obj;
          });
        }
        this.initMap();
      });
    },
  },
};
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Vue使用Echarts实现立体柱状图

    本文实例为大家分享了Vue使用Echarts实现立体柱状图的具体代码,供大家参考,具体内容如下 预览: 代码: 页面部分: <template> <div class="roadnum-all" ref="roadnumall"> <div id="roadnum" ref="dom"></div> </div> </template> CSS部分: .r

  • vue+echarts实现进度条式柱状图

    本文实例为大家分享了vue+echarts实现进度条式柱状图的具体代码,供大家参考,具体内容如下 效果图如下 代码: <template> <div class="content-page"> <div class="tab-content"> <div id="myChart1"></div> </div> </div> </template> &l

  • vue实现横向斜切柱状图

    本文实例为大家分享了vue实现横向斜切柱状图的具体代码,供大家参考,具体内容如下 实现效果: 实现代码: <template> <div class="Consumption"> <div style="width: 350px; height: 180px" ref="ConsumptionChart" /> </div> </template> <script> impo

  • vue echarts实现横向柱状图

    本文实例为大家分享了vue echarts实现横向柱状图的具体代码,供大家参考,具体内容如下 实现效果: 代码: <template> <div class="OverYearsPompany"> <div id="OverYearsPompanyChart" style="flex: 1; height: 368px; margin-top: -42px"></div> </div>

  • vue echarts实现柱状图动态展示

    本文实例为大家分享了vue echarts实现柱状图动态展示的具体代码,供大家参考,具体内容如下 轮播图形式展现 <template> <div class="dan"> <div id="scalesize" :style="{width: '100%', height: '100%'}"></div> </div> </template> <script> i

  • Vue echart实现柱状图,电池图,3D柱图和3D圆柱图代码详解

    目录 电池图 3D柱状图+3个柱图+图例不能点击 3D圆筒柱状图 3D圆筒柱状图+背景 电池图 自动播放+底部可拖拽 比电池图好看一点的进度条 总结 电池图 let backgroundColor = 'rgba(0,0,0,1)'; let chartdata = [ [111, 222, 333, 444], ['石油', '煤矿', '汽油', '电力'], ]; var getmydmc = chartdata[1]; //数据点名称 var getmyd = chartdata[0];

  • Vue+Echart柱状图实现疫情数据统计

    目录 1.首先在项目中安装echarts 2.在echarts引入柱形图模板 3.通过API引入数据 4.整合代码 四步走四步走,要是直接跳到最后的话,记得有些依赖和环境配置一下哦. 1.首先在项目中安装echarts 1.安装echarts依赖包 npm install echarts --save 2.在plugins目录下创建echarts.js文件并在里面引入echarts依赖包 import Vue from 'vue' import echarts from 'echarts'//这

  • 详解vue使用Echarts画柱状图

    目录 1 引入Echarts 1.1 安装 1.2 引入 2 基本柱状图 3 多列柱状图 4 柱状图样式设置 4.1 柱条样式 4.2 柱条间距 5 动态排序柱状图 6 总结 1 引入Echarts 1.1 安装 使用如下命令通过 npm 安装 ECharts npm install echarts --save 注:本文安装Echarts版本为:“echarts”: “5.2.1” 1.2 引入 安装完成以后,可以将echarts全部引入,这样一来,我们可以在该页面使用echarts所有组件:

  • vue+echarts实现堆叠柱状图

    本文实例为大家分享了vue+echarts实现堆叠柱状图的具体代码,供大家参考,具体内容如下 echarts-子组件 <template> <div class="chart" ref="chartEle"></div> </template> <script> import echarts from "echarts"; import eventBus from '@/componen

  • vue+echart实现双柱状图

    本文实例为大家分享了vue+echart实现双柱状图的具体代码,供大家参考,具体内容如下 效果图: 一.安装 版本号建议安装"echarts": "^4.8.0",其它版本init会报错 1. 首先需要安装echarts依赖包 npm install --save echarts@4.8.0 2. 或者使用国内的淘宝镜像: npm install -g cnpm --registry=https://registry.npm.taobao.org <templ

随机推荐