Vue封装EChat组件

目的

  1. 减少重复代码量
  2. 统一风格
  3. 全局事件处理方便维护
  4. 可以根据实际需求暴露对应的事件和方法
### 代码
<template>
  <div ref="chart" class="my-chart"></div>
</template>

<script>
import * as echarts from 'echarts'
export default {
  name: 'EChart',
  props: {
    option: {
      type: Object,
      default: () => {
        return null
      }
    }
  },
  data() {
    return {
      myChart: null
    }
  },
  watch: {
    option(newValue) {
      if (newValue) {
        this.loadChart()
      }
    }
  },
  mounted() {
    this.myChart = echarts.init(this.$refs.chart)
    if (this.option) {
      this.loadChart()
    } else {
      this.myChart.showLoading({
        text: '数据加载中...',
        color: '#81B5FD',
        textColor: '#81B5FD',
        maskColor: 'rgba(255, 255, 255, 0.2)',
        showSpinner: false,
        zlevel: 0
      })
    }
  },
  methods: {
    loadChart() {
      this.myChart.hideLoading()
      this.myChart.setOption(this.option)
      window.addEventListener('resize', () => {
        this.myChart.resize()
      })
    }
  }
}
</script>

<style lang="less" scoped>
.my-chart {
  width: 100%;
  height: 100%;
}
</style>

使用

<template>
  <my-card title="业务类别">
    <e-chart :option="option" />
  </my-card>
</template>
<script>
export default {
  name: 'BusinessCategory',
  data() {
    return {
      option: null,
      seriesData: [
        { value: 1048, name: '房建' },
        { value: 735, name: '铁路' },
        { value: 580, name: '公路' },
        { value: 484, name: '贸易' },
        { value: 300, name: '境外开矿' }
      ]
    }
  },
  mounted() {
    this.handleChartInit()
  },
  methods: {
    handleChartInit() {
      this.option = {
        tooltip: {
          trigger: 'item',
          formatter: '{b} </br>{c}({d}%)'
        },
        label: {
          alignTo: 'edge',
          formatter: '{name|{b}}\n{time|{c}} ({time|{d}}%)',
          minMargin: 5,
          edgeDistance: 10,
          lineHeight: 15,
          rich: {
            time: {
              fontSize: 10,
              color: '#999'
            }
          }
        },
        series: [
          {
            name: 'Access From',
            type: 'pie',
            radius: ['45%', '70%'],
            data: this.seriesData,
            emphasis: {
              itemStyle: {
                shadowBlur: 10,
                shadowOffsetX: 0,
                shadowColor: 'rgba(0, 0, 0, 0.5)'
              }
            }
          }
        ]
      }
    }
  }
}
</script>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,859评论 2 59
  • Android组件化项目地址:Android组件化项目AndroidModulePattern Android组件...
    半灬边灬天阅读 2,940评论 4 37
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,135评论 1 32
  • 不怕跌倒,所以飞翔 组件化开发 参考资源 Android组件化方案 为什么要组件化开发 解决问题 实际业务变化非常...
    笔墨Android阅读 3,006评论 0 0
  • 前言 您将在本文当中了解到,往网页中添加数据,从传统的dom操作过渡到数据层操作,实现同一个目标,两种不同的方式....
    itclanCoder阅读 25,885评论 1 12