echarts bar chart pie chart switching

Code:

<template>
  <div class="wrap">
    <div  v-for="(item,index) in cuurentData" :key="index">
      <div class="chartsBar" :id="`chartsBar${index}`" :style="{ width: '315px', height: '270px' }" :v-show="show['barShow'+index]"></div>
      <div class="chartsPie" :id="`chartsPie${index}`" :style="{ width: '315px', height: '270px' }" :v-show="show['pieShow'+index]"></div>
    </div>
  </div>
</template>

<script>
export default {
  props:['chartData'],
  data() {
    return {
      show:{},
      cuurentData:[],
      pieShow:{}
    };
  },
  watch:{
    chartData:{
      handler(newValue){
        this.cuurentData = newValue;
        if(this.cuurentData.length>0){
          for (let i = 0; i < this.cuurentData.length; i++) {
            this.$set(this.show,'barShow'+i,false);
            this.$set(this.show,'pieShow'+i,false);
          }
          this.$nextTick(()=>{
            this.initChart()
          })
        }
      },

      deep:true
    }
  },
  created() {},
  mounted() {},
  methods: {
    // 折线、柱状
    initChart(){
      let that = this;
      let optionBar;
      let optionPie;
      let chartBar;
      let chartPie;
      let colors =['rgba(166, 83, 90, 1)','rgba(254, 215, 26, 1)','rgba(239, 130, 160, 1)','rgba(183, 63, 160, 1)',
        'rgba(92, 30, 25, 1)','rgba(131, 167, 141, 1)','rgba(128, 118, 163, 1)','rgba(36, 116, 181, 1)',
        'rgba(142, 139, 88, 1)','rgba(186, 207, 101, 1)', 'rgba(238, 44, 37, 1)','rgba(59, 129, 140, 1)',
        'rgba(19, 72, 87, 1)','rgba(153, 164, 157, 1)','rgba(55, 182, 65, 1)','rgba(224, 147, 0, 1)',
        'rgba(24, 45, 180, 1)','rgba(125, 190, 255, 1)','rgba(100, 88, 34, 1)','rgba(239, 111, 72, 1)',
        'rgba(86, 88, 91, 1)','rgba(156, 21, 8, 1)','rgba(51, 91, 63, 1)','rgba(85,239,229,1)',
        'rgba(99,243,136,1)'];
      for (let i = 0; i < this.cuurentData.length; i++) {
        let barSeries = []
        for (let j = 0; j < this.cuurentData[i].data.yaxisData.length; j++) { // 柱状图系列数据处理
          barSeries.push({
            type: 'bar',
            name: this.cuurentData[i].data.yaxisData[j].name,
            data: this.cuurentData[i].data.yaxisData[j].data,
            itemStyle: {
              normal: {
                color: function (d) {
                  // return "#"+Math.floor(Math.random()*(256*256*256-1)).toString(16);
                  return colors[Math.floor(Math.random() * 26)]
                }
              }
            }
          })
        }

        if(this.cuurentData[i].data.pieData){ // 是否显示饼图按钮
          this.$set(this.pieShow, 'myPieShow' + i, true )
        }else {
          this.$set(this.pieShow, 'myPieShow' + i, false )
        }
        chartBar = this.$echarts.init(document.getElementById(`chartsBar${i}`));
        chartPie = this.$echarts.init(document.getElementById(`chartsPie${i}`));
        // 初始让所有的饼图隐藏位置
        document.getElementById('chartsPie'+i).style.display = 'none';
        // 柱状图配置
        optionBar = {
          title: {
            text: this.cuurentData[i].title,
            subtext:this.cuurentData[i].subTitle,
            textStyle:{
              fontSize:16,
              lineHeight:10,
            },
            subtextStyle:{
              fontSize:14,
              color:'#545454',
              fontWeight:'bold',
            },
            top:5
          },
          tooltip: {
            trigger: 'axis',
            position: ['10%', '50%'],
          },
          grid:{
            left:37,
            bottom:'21%',
            top:'22%'
          },
          toolbox: {
            show: true,
            itemSize:18,
            showTitle:true,
            feature: {
              magicType: { show: true, type: ['line', 'bar'] },
              myPie: {
                show: this.pieShow['myPieShow'+i], // 切换饼图的按钮是否显示
                title: '切换为饼状图',
                icon: 'path://M512 0a512 512 0 1 0 512 512A512 512 0 0 0 512 0z m460.1856 489.8816H537.6V52.0192a461.2096 461.2096 0 0 1 434.5856 437.8624z m0 51.2a458.752 458.752 0 0 1-93.3888 249.4464L582.0416 541.0816zM512 972.8a460.8 460.8 0 0 1-25.6-921.6v464.2816a25.8048 25.8048 0 0 0 9.8304 20.48L845.6192 829.44a459.776 459.776 0 0 1-333.6192 143.36z',
                onclick: ()=> {
                  chartPie.setOption(optionPie);
                  this.$nextTick(()=>{
                    document.getElementById('chartsBar'+i).style.display = 'none';
                    document.getElementById('chartsPie'+i).style.display = 'block';
                  })
                }
              },
              restore: { show: true },
            },
            position:[20,20]
          },
          calculable: true,
          xAxis: [
            {
              type: 'category',
              data: this.cuurentData[i].data.xaxisData,
              axisLabel: {
                interval:0,
                formatter:function(value) {
                  return value.split("").join("\n");
                }
              }
            }
          ],
          yAxis: {
            type: 'value',
            axisLabel: {
              color: '#444343',
              formatter: function (value, index) {
                // value大于10000时除以10000并拼接w,小于1000按原格式显示
                if (value >= 10000) {
                  value = value / 10000 + 'w';
                } else if (value < 10000) {
                  value;
                }
                return value;
              },
            },
          },
          series: barSeries,
        };

        // 饼状图配置
        optionPie = {
          title: {
            text: this.cuurentData[i].title,
            subtext:this.cuurentData[i].subTitle,
            textStyle:{
              fontSize:16,
              lineHeight:10,
            },
            subtextStyle:{
              fontSize:14,
              color:'#545454',
              fontWeight:'bold',
            },
            top:5
          },
          tooltip: {
            position: ['10%', '50%'],
            formatter: '{a}: <br/>{b} : {c} ({d}%)',
          },
          toolbox: {
            show: true,
            itemSize:18,
            showTitle:true,
            feature: {
              myBar: {
                show: true,
                title: '切换为柱状图',
                icon: 'image://',
                onclick: () => {
                  chartBar.setOption(optionBar);
                  this.$nextTick(() => {
                    document.getElementById('chartsBar' + i).style.display = 'block';
                    document.getElementById('chartsPie' + i).style.display = 'none';
                  })
                }
              },
              myPie: {
                show: true,
                title: '切换为饼状图',
                icon: 'path://M512 0a512 512 0 1 0 512 512A512 512 0 0 0 512 0z m460.1856 489.8816H537.6V52.0192a461.2096 461.2096 0 0 1 434.5856 437.8624z m0 51.2a458.752 458.752 0 0 1-93.3888 249.4464L582.0416 541.0816zM512 972.8a460.8 460.8 0 0 1-25.6-921.6v464.2816a25.8048 25.8048 0 0 0 9.8304 20.48L845.6192 829.44a459.776 459.776 0 0 1-333.6192 143.36z',
                onclick: function () {
                }
              },
              restore: {show: true},
            }
          },
          calculable: true,
          series:
            [
            {
              name: "人口数",
              type: 'pie',
              radius: '50%',
              top:40,
              data: this.cuurentData[i].data.pieData,
              itemStyle: {
                normal: {
                  color: function(d){
                    // return "#"+Math.floor(Math.random()*(256*256*256-1)).toString(16);
                    return colors[Math.floor(Math.random()*26)]
                  }
                }
              }
            }
          ]
        };

        // 使用刚指定的配置项和数据显示图表。
        chartBar.setOption(optionBar);
        chartPie.setOption(optionPie);
      }
    },
  }
};
</script>

<style scoped>
/* 请根据实际需求修改父元素尺寸,组件自动识别宽高 */
.wrap,
.chartsBar,
.chartsPie{
  width: 100%;
  height: 260px;
}
</style>

Rendering:

Guess you like

Origin blog.csdn.net/weixin_46029283/article/details/131396435