IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 纯Vue项目使用Echarts -> 正文阅读

[JavaScript知识库]纯Vue项目使用Echarts

  • 纯Vue项目如何引入Echarts
    1. 安装 (不解释)
    2. 全局引入,main.js文件中引入并挂接,不是在.vue文件里
import * as echarts from 'echarts'
Vue.prototype.$echarts = echarts
  • 饼状图模板(抽取成了外部独立模块,含toolbox自定义下载组件)+ 调用方式
<template>
  <div ref="chart"></div>
</template>

<script>
import {statistic} from '@/api/mobileActiveStatistic'

export default {
  name: 'pieChart',
  components: {},
  props: {
    sup_this: {
      type: Object,
      default: null
    }
  },
  data() {
    return {
      datas: [],
      globaleFuncNames: []
    }
  },
  methods: {
    /*饼状图初始化*/
    init() {
      // 初始化echarts实例
      this.sup_this.myChart = this.$echarts.init(this.$refs.chart);
      this.sup_this.myChart.resize({
        width: 1000,
        height: 400
      });
      // 绘制图表
      this.sup_this.myChart.setOption({
        title: {
          text: '主标题',//主标题
          subtext: '副标题',//副标题
          x: 'center',//x轴方向对齐方式
        },
        toolbox: {
          show: true,
          feature: {
            saveAsImage: {
              icon: 'path://M 384 448 V 110 h 230 v 310 h 180 l -300 324 l -324 -324 h 180 Z m -170 450 h 600 v 60 H 140 v -60 Z',
              iconStyle: {
                color: '#000'
              },
            }
          }
        },
        tooltip: {
          trigger: 'item',
          formatter: "{a} <br/>{b} : {c} ({d}%)",
        },
        legend: {
          type: 'scroll',
          orient: 'vertical',
          right: 10,
          top: 50,
          bottom: 20,
          data: this.globaleFuncNames //例:['注例1','注例2','注例3']
        },
        series: [
          {
            name: '数据来源',
            type: 'pie',
            radius: '55%',
            center: ['50%', '60%'],
            data: this.datas, // 例:[{'value':238,'name':'注例1'}, {'value':152,'name':'注例2'}]
            itemStyle: {
              emphasis: {
                shadowBlur: 10,
                shadowOffsetX: 0,
                shadowColor: 'rgba(0, 0, 0, 0.5)'
              }
            }
          }
        ]
      });
    },

    /*饼状图数据处理*/
    async pieChartDataHandleAndInit() {
      // 业务逻辑准备需要的数据,替换 this.datas 和 this.globaleFuncNames
      /*初始化*/
      this.init();
    },

  }
}
</script>
<template>
	<el-divider content-position="left">统计结果展示</el-divider>
	<pie-chart ref="pieChart" :sup_this="sup_this"></pie-chart>
	
	<div slot="footer" class="dialog-footer">
      <el-button :loading="loading" type="primary" @click="onSubmit">查询</el-button>
    </div>
</template>

<script>
import pieChart from './pieChart'
export default {
	components: { PieChart},
  	data() {
  		return {
  			sup_this:this
  		}
  	},
  	methods: {
  		onSubmit() {
  			// 业务逻辑...略
  			this.initPieChart();
  		},
  		
  		/*初始化饼状图*/
	    initPieChart() {
	      const _this = this.$refs.pieChart;
	      _this.pieChartDataHandleAndInit();
	    }
  	}
}
</script>

结合业务逻辑,实现效果下图这样:在这里插入图片描述

  • 折线图模板(抽取成了外部独立模块,含toolbox自定义下载组件)+ 调用方式
<template>
  <div ref="chart"></div>
</template>

<script>
import {statistic} from '@/api/mobileActiveStatistic'

export default {
  name: 'lineChart',
  components: {},
  props: {
    sup_this: {
      type: Object,
      default: null
    }
  },
  data() {
    return {
      labels: [],
      series: []
    }
  },
  mounted() {
  },
  methods: {

    /*初始化折线图*/
    init() {
      this.sup_this.myChart = this.$echarts.init(this.$refs.chart);
      this.sup_this.myChart.resize({
        width: 1000,
        height: 400
      });
      this.sup_this.myChart.setOption({
        tooltip: {
          trigger: "axis",
        },
        toolbox: {
          show: true,
          feature: {
            saveAsImage: {
              icon: 'path://M 384 448 V 110 h 230 v 310 h 180 l -300 324 l -324 -324 h 180 Z m -170 450 h 600 v 60 H 140 v -60 Z',
              iconStyle: {
                color: '#000'
              },
            }
          }
        },
        legend: {
          type: 'scroll',
          width: 500,
          data: this.labels // 例:['注例1','注例2']
        },
        grid: {
          left: "3%",
          right: "4%",
          bottom: "3%",
          containLabel: true,
        },
        xAxis: {
          type: "category",
          boundaryGap: false,
          data: this.sup_this.form.years, // 例:['2019','2020','2021']
        },
        yAxis: {},
        series: this.series, // 例:[ {data: [10, 22, 28],type: 'line'}, {data: [62, 72, 56],type: 'line'}]
      });
    },

    /*折线图数据初始化*/
    async lineChartDataHandleAndInit() {
      // 业务逻辑...略,为 this.labels 和 this.series 和 this.sup_this.form.years 赋值
      // 初始化折线图
      this.init()
    },
  }
}
</script>
<template>
	<el-divider content-position="left">统计结果展示</el-divider>
	<line-chart ref="lineChart" :sup_this="sup_this"></line-chart>
	
	<div slot="footer" class="dialog-footer">
      <el-button :loading="loading" type="primary" @click="onSubmit">查询</el-button>
    </div>
</template>

<script>
import lineChart from "./lineChart";
export default {
	components: { lineChart },
  	data() {
  		return {
  			sup_this:this
  		}
  	},
  	methods: {
  		onSubmit() {
  			// 业务逻辑...略
  			this.initLineChart();
  		},
  		
  		/*初始化折线图*/
	    initLineChart() {
	      const _this = this.$refs.lineChart;
	      _this.lineChartDataHandleAndInit();
	    }
  	}
}
</script>

结合业务逻辑,实现效果下图这样:在这里插入图片描述

  • 柱状图…待更新
  • 未完待续
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-10-22 21:06:34  更:2022-10-22 21:08:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 17:45:01-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码