echarts 柱状堆叠双X轴的概括实现


<v-chart :options="options" :auto-resize="true" style="height: 500px; width: 100%;">

export default {

// 父组件传递过来的数据 (两种方式声明:1.数组 2.对象)

  props: {

titleText: {

type:String,

      default: () => {

return ''

      }

}, // 图表名称

    isPercentage: {

type:Boolean

    }, // 是否是%

    // 原来的数组传入

    inSeriesData: {

type:Array,

      default: () => {

return [

[20, 20, 0, 0, 20, 0, 20, 20, 20, 20],

          [20, 20, 20, 0, 20, 20, 20, 20, 20, 20],

          [10, 10, 10, 50, 0, 30, 20, 20, 20, 20],

          [10, 10, 10, 50, 40, 30, 20, 20, 20, 20],

          [10, 20, 30, 0, 30, 0, 20, 20, 20, 20],

          [30, 20, 30, 0, 0, 20, 20, 20, 20, 20]

]

}

}, // 原来的数组传入

    legendData: {

type:Array,

      default: () => {

return ['I类', 'II类', 'III类', 'IV类', 'V类', '劣V类']// 图表图标数据

      }

}, // 原来的数组传入

    xAxisDataI: {

type:Array,

      default: () => {

return [

[1, 2, 0, 0, 2, 0, 2, 2, 2, 2],

          [1, 2, 2, 0, 2, 2, 2, 2, 2, 2],

          [1, 1, 1, 5, 0, 3, 2, 2, 2, 2],

          [1, 1, 1, 5, 3, 3, 2, 2, 2, 2],

          [1, 1, 1, 0, 4, 0, 2, 2, 2, 2],

          [1, 2, 3, 0, 0, 2, 2, 2, 2, 2],

          [1, 2, 3, 0, 0, 0, 2, 2, 2, 2]

]

}

},

    xAxisDataII: {

type:Array,

      default: () => {

return ['白龙江', '黑河水', '黄河干流', '嘉陵江', '石羊河']

}

},

    yAxisMax: {

type: [Number, String],

      default: () => {

return '100'

      }

}

},

  // 数据

  data() {

return {

options: {},

      series: [],

      xAxisData: []

}

},

  // 要用到哪些子组件

  components: {},

  // 计算属性

  computed: {},

  // 监听

  watch: {},

  // 生命周期钩子:实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用

  created() {

this.setSeries()

},

  // 生命周期钩子:组件实例渲染完成时调用

  mounted() {

},

  // 函数集,

  methods: {

setOption() {

let xAxisData = []

let series = []

this.xAxisData = []

this.xAxisDataII.forEach(item => {

xAxisData.push({

value: item,

          textStyle: {

fontSize:18,

            lineHeight:70

          }

})

})

this.legendData.forEach((item, index) => {

series.push(

{

name: item,

            type:'bar',

            stack:'one',

            barMaxWidth:'36.66%',

            label: {

show:true,

              formatter: (params) => {

let value =this.xAxisDataI[params.seriesIndex][params.dataIndex]

if (Number(value) &&Number(value) !==0) {

return value

}

return ''

              },

              textStyle: {

color:'#474747'

              },

              position:'inside'

            },

            data:this.inSeriesData[index]

}

)

})

let num =Math.ceil(this.inSeriesData[0].length /2)

// eslint-disable-next-line no-unused-vars

      for (let i =0; i < num; i++) {

let list = ['当期', '同期']

this.xAxisData.push(...list)

}

this.options = {

title: {

text:this.titleText

        },

        color:this.$config.chartsColor,

        tooltip: {

trigger:'axis',

          axisPointer: {

type:'cross'

          }

},

        grid: [

{

top:100,

            bottom:101

          },

          {

height:60,

            bottom:40

          }

],

        toolbox: {

feature: {

dataView: {show:true, readOnly:false },

            restore: {show:true },

            saveAsImage: {show:true }

}

},

        legend: {

data:this.legendData

        },

        xAxis: [

{

type:'category',

            data:this.xAxisData

          }, {

type:'category',

            data: xAxisData,

            position:'bottom',

            axisTick: {

length:50

            },

            splitArea: {

show:true,

              areaStyle: {

/* color: ['rgba(255,255,255,0.5)', 'rgba(200,200,200,0.5)'] */

              }

}

}

],

        yAxis: [

{

type:'value',

            name:'',

            min:0,

            max:this.yAxisMax,

            position:'left',

            axisLine: {

lineStyle: {

// color: this.$config.color[0]

              }

},

            axisLabel: {

formatter:this.isPercentage ?'{value} %' :'{value}'

            }

}

],

        series: series

}

},

    setSeries() {

this.setOption()

}

}

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352