Bootstrap

折线图柱形图饼图三图自由切换

效果:

vue2写法:

<template>
  <div class="perstatimg">
    <div v-show="pieshow" id="myChartpie" class="myChartpie" :style="{ width: '100%', height: '500px' }" />
    <div v-show="barshow" id="myChart" class="myChart" :style="{ width: '100%', height: '500px' }" />
  </div>
</template>

<script>
export default {
  data() {
    return {
    	barshow: true,
      pieshow: true
    }
  },
  mounted() {
    this.drawLine()
  },
  methods: {
    // 绘制当前用户图表
    drawLine() {
      const newTitle = '水果数量'
      // 基于准备好的dom,初始化echarts实例
      const myChart = this.$echarts.init(document.getElementById('myChart'))
      const myChartpie = this.$echarts.init(document.getElementById('myChartpie'))
      // 绘制图表
      myChart.setOption({
        // title: { text: "当前用户的点击量", subtext: "纯属虚构" },
        title: { text: newTitle },
        tooltip: { trigger: 'axis' },
        legend: {
          data: ['点击量']
        },
        toolbox: {
          show: true,
          feature: {
            myTool: {
              show: true,
              title: '切换为饼图',
              icon: 'image://',
              iconStyle: {
                color: 'rgba(232, 17, 17, 1)'
              },
              onclick: function() {
                const myChartline = document.getElementById('myChart')
                const myChartpie2 = document.getElementById('myChartpie')
                myChartline.style.display = 'none'
                myChartpie2.style.display = 'block'
              }
            },
            magicType: { type: ['bar', 'line'] },
            // restore: {},
            saveAsImage: {}
            // dataView: {
            //   readOnly: false
            // },
          }
        },
        xAxis: {
          type: 'category',
          boundaryGap: true,
          data: [],
          axisLabel: {
            interval: 0,
            rotate: 20,
            fontSize: 12,
            color: 'rgba(0, 0, 0, 1)'
          }
        },
        grid: {
          bottom: '100px'
        },
        dataZoom: [{
          realtime: true, // 拖动滚动条时是否动态的更新图表数据
          height: 25, // 滚动条高度
          start: 0, // 滚动条开始位置(共100等份)
          end: 50 // 结束位置(共100等份)
        }, {
          start: 0
        }],
        yAxis: {
          type: 'value',
          axisLabel: {
            formatter: '{value}'
          }
        },
        series: [
          {
            name: '访问量',
            type: 'bar',
            data: [],
            itemStyle: {
              color: '#99CCFF'
            }
          }
        ]
      })
      myChartpie.setOption({
        title: { text: newTitle },
        tooltip: {
          trigger: 'axis'
        },
        legend: {
          textStyle: { // 图例文字的样式
            color: '#0b2b5e',
            fontSize: 32
          },
          data: ['点击量']
        },
        toolbox: {
          show: true,
          feature: {
            myTool: {
              show: true,
              title: '切换为柱状图',
              icon: 'image://',
              iconStyle: {
                color: 'rgba(232, 17, 17, 0)'
              },
              onclick: function() {
                const myChartline = document.getElementById('myChart')
                const myChartpie2 = document.getElementById('myChartpie')
                myChartline.style.display = 'block'
                myChartpie2.style.display = 'none'
              }
            },
            // restore: {},
            saveAsImage: {}
          }
        },
        series: [
          {
            name: '访问量',
            type: 'pie',
            id: 'pie',
            radius: '70%',
            center: ['50%', '50%'],
            label: {
              formatter: '{b}: {@2012} ({d}%)',
              textStyle: {
                fontSize: 16
              }
            },
            data: [],
            itemStyle: {
              emphasis: {
                hadowBlur: 10,
                shadowOffsetX: 0,
                shadowColor: 'rgba(0, 0, 0, 0.5)'
              },
              normal: {
                color: function(params) {
                  // 自定义颜色
                  var colorList = [
                    '#0780cf', '#765005', '#fa6d1d', '#0e2c82', '#b6b51f', '#da1f18', '#701866', '#f47a75', '#009db2', '#024b51',
                    '#0780cf', '#765005', '#fa6d1d', '#0e2c82', '#b6b51f', '#da1f18', '#701866', '#f47a75', '#009db2', '#024b51'
                  ]
                  return colorList[params.dataIndex]
                }
              }
            }
          }
        ]
      }
      )
      // 静态数据时
      myChart.setOption(
        (this.option = {
          xAxis: {
            data: ['苹果', '梨', '桃子', '橘子', '橙子', '芒果', '香蕉', '草莓', '榴莲', '西瓜']
          },
          series: [
            {
              data: ['39', '34', '29', '16', '40', '20', '20', '10', '10', '10']
            }
          ]
        })
      )
      myChartpie.setOption(
        (this.option = {
          series: [
            {
              data: [
                { value: '39', name: '苹果' },
                { value: '34', name: '梨' },
                { value: '29', name: '桃子' },
                { value: '16', name: '橘子' },
                { value: '40', name: '橙子' },
                { value: '20', name: '芒果' },
                { value: '20', name: '香蕉' },
                { value: '10', name: '草莓' },
                { value: '10', name: '榴莲' },
                { value: '10', name: '西瓜' }]
            }
          ]
        })
      )
      // 请求数据时
      // this.$axios.post("axiosurl", {"startDate": "", "endDate": ""}).then((res) => {
      //   this.resData = res.data;
      //   let PersonalAppName = new Array()
      //   let PersonalCount = new Array()
      //   let NewPersonalAppName = ""
      //   let NewPersonalCount = ""
      //   let NewPersonal = new Array();
      //   for (let i = 0; i < this.resData.length; i++) {
      //     PersonalAppName[i] = this.resData[i].name;
      //     NewPersonalAppName = this.resData[i].name;
      //     PersonalCount[i] = this.resData[i].count;
      //     NewPersonalCount = this.resData[i].count;
      //     NewPersonal[i] = {value: NewPersonalCount, name: NewPersonalname}
      //   }
      //   for (let i = 0; i < this.resData.length; i++) {
      //      PersonalAppName[i] = this.resData[i].name
      //      PersonalCount[i] = this.resData[i].count
      //   }
      //   if (PersonalAppName.length <= 0 || PersonalCount.length <= 0){
      //     // this.$message("暂无数据!!!");
      //     this.haveData = false;
      //     this.noData = true;
      //     return;
      //   } else {
      //     this.haveData = true;
      //     this.noData = false;
      //   }
      //   myChart.setOption(
      //     (this.option = {
      //       xAxis: {
      //         data: PersonalAppName,
      //       },
      //       series: [
      //         {
      //           data: PersonalCount,
      //         }
      //       ]
      //     })
      //   );
      //   myChartpie.setOption(
      //     (this.option = {
      //       series: [
      //         {
      //           data: NewPersonal
      //         }
      //       ]
      //     })
      //   );
      // })
    }
  }
}
</script>
<style>
.perstatimg{
  margin-top:20px;
  height: 500px;
  overflow: hidden;
}
</style>

react写法:

​
import React ,{Component} from "react";
import * as echarts from 'echarts';
export default class EchartsColumnar extends Component {
    constructor(props){
        super(props); 
        this.state={}
    }
  //方法的地方
  componentDidMount() {
  // const newTitle = '案件统计'
  // 基于准备好的dom,初始化echarts实例
    var chartDom = document.getElementById('myChart');
    var chartDomPie = document.getElementById('myChartpie');
    var myChart = echarts.init(chartDom);   
    var myChartpie = echarts.init(chartDomPie);   
  // 绘制图表
  myChart.setOption({
    // title: { text: newTitle },
    tooltip: { trigger: 'axis' },
    legend: {
      data: ['点击量']
    },
    toolbox: {
      show: true,
      feature: {
        myTool: {
          show: true,
          title: '切换为饼图',
          icon: 'image://',
          iconStyle: {
            color: 'rgba(232, 17, 17, 1)'
          },
          onclick: function() {
            const myChartline = document.getElementById('myChart')
            const myChartpie2 = document.getElementById('myChartpie')
            myChartline.style.display = 'none'
            myChartpie2.style.display = 'block'
          }
        },
        magicType: { type: ['bar', 'line'] }
      }
    },
    xAxis: {
      type: 'category',
      boundaryGap: true,
      data: this.props.data.content.stdata,
      axisLabel: {
        interval: 0,
        rotate: 20,
        fontSize: 12,
        color: 'rgba(0, 0, 0, 1)'
      }
    },
    grid: {
      bottom: '100px'
    },
    yAxis: {
      type: 'value',
      axisLabel: {
        formatter: '{value}'
      }
    },
    series: [
      {
        name: '访问量',
        type: 'bar',
        data: this.props.data.content.data,
        itemStyle: {
          color: '#99CCFF'
        }
      }
    ]
  })
  myChartpie.setOption({
    // title: { text: newTitle },
    toolbox: {
      show: true,
      feature: {
        myTool: {
          show: true,
          title: '切换为柱状图',
          icon: 'image://',
          iconStyle: {
            color: 'rgba(232, 17, 17, 0)'
          },
          onclick: function() {
            const myChartline = document.getElementById('myChart')
            const myChartpie2 = document.getElementById('myChartpie')
            myChartline.style.display = 'block'
            myChartpie2.style.display = 'none'
          },
        }
      }
    },
    series: [
      {
        type: 'pie',
        id: 'pie',
        radius: '40%',
        center: ['50%', '40%'],
        label: {
          formatter: '{b}: {@2012} ({d}%)',
          textStyle: {
            fontSize: 10
          }
        },
        data: this.props.data.content.data,
        itemStyle: {
          emphasis: {
            hadowBlur: 10,
            shadowOffsetX: 0,
            shadowColor: 'rgba(0, 0, 0, 0.5)'
          },
          normal: {
            color: function(params) {
              // 自定义颜色
              var colorList = [
                '#0780cf', '#765005', '#fa6d1d', '#0e2c82', '#b6b51f', '#da1f18', '#701866', '#f47a75', '#009db2', '#024b51',
                '#0780cf', '#765005', '#fa6d1d', '#0e2c82', '#b6b51f', '#da1f18', '#701866', '#f47a75', '#009db2', '#024b51'
              ]
              return colorList[params.dataIndex]
            }
          }
        }
      }
    ]
  }
  )
  }


render(){

    return(
       <div>
        <div style={{paddingLeft:"20px",paddingTop:"10px"}}>您好,查询到有<span  className="total"> {this.props.data.content.total} </span>个案件信息。</div>
       <div id="myChart" className="myChart" style={{width : "450px" , height: "300px"}} />
       <div id="myChartpie" className="myChartpie"  style={{width : "450px" , height: "300px",display:"none"}}/>
     </div>
    )
}
}

;