VUE整合Echarts实现简单的数据可视化




<template>
  <div>
    <el-row :gutter="20">
      <el-col :span="12">
        <el-card class="box-card">
          <div slot="header" class="clearfix">
            <span>用户来源</span>
          </div>
          <div ref="sourceChart" style="height: 300px;"></div>
        </el-card>
      </el-col>
      <el-col :span="12">
        <el-card class="box-card">
          <div slot="header" class="clearfix">
            <span>用户分布</span>
          </div>
          <div ref="distributionChart" style="height: 300px;"></div>
        </el-card>
      </el-col>
    </el-row>
  </div>
</template>
 
<script>
import * as echarts from 'echarts';
 
export default {
  name: 'UserAnalysis',
  data() {
    return {
      sourceData: {
        legend: ['直接访问', '邮件营销', '联盟广告', '视频广告', '搜索引擎'],
        series: [33, 22, 33, 55, 66]
      },
      distributionData: {
        legend: ['桌面', '移动', '平板'],
        series: [33, 22, 44]
      }
    };
  },
  mounted() {
    this.initCharts();
  },
  methods: {
    initCharts() {
      const sourceChart = echarts.init(this.$refs.sourceChart);
      const distributionChart = echarts.init(this.$refs.distributionChart);
 
      const option = {
        color: ['#5470C6', '#91CC75', '#FAC858', '#EE6666', '#73C0DE'],
        series: [
          {
            name: '访问来源',
            type: 'pie',
            radius: '55%',
            data: this.sourceData.series.map((value, index) => ({ value, name: this.sourceData.legend[index] }))
          }
        ]
      };
 
      sourceChart.setOption(option);
 
      const distributionOption = {
        color: ['#5470C6', '#91CC75', '#FAC858'],
        series: [
          {
            name: '设备分布',
            type: 'pie',
            radius: '55%',
            data: this.distributionData.series.map((value, index) => ({ value, name: this.distributionData.legend[index] }))
          }
        ]
      };
 
      distributionChart.setOption(distributionOption);
    }
  }
};
</script>
 
<style scoped>
.box-card {
  margin-bottom: 20px;
}
</style>

这个代码实例使用Vue和Element UI来构建用户界面,并通过ECharts绘制图表。在data函数中定义了两组用于ECharts图表的数据,在mounted钩子中调用initCharts方法来初始化图表。initCharts方法中使用ECharts的实例方法init来在对应的DOM元素上初始化图表,并设置相应的配置项。这个例子展示了如何在Vue项目中整合ECharts,并简单地展示了两个饼图的绘制。

最后修改于:2024年08月13日 09:03

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日