Vue使用Echarts折线图,实现点击播放、暂停、选择播放倍数;实现数据直播功能

简介: Vue使用Echarts折线图,实现点击播放、暂停、选择播放倍数;实现数据直播功能

🌟前言

哈喽小伙伴们,最近公司有个小需求,就是基于Echarts的折线图,做一个数据直播的功能;拿到所有图表数据之后,通过点击播放,暂停,选择播放倍数来实现相应的效果,更直观的为客户展现数据变化的过程;那接下来我们一起来看看吧

🌟先看效果

Echarts折线图逐点播放

🌟整体代码(详细注释)

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Echarts折线图逐点播放</title>
  <!-- 引入vue.js -->
  <script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
  <!-- 引入element的css -->
  <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
  <!-- 引入组件库 -->
  <script src="https://unpkg.com/element-ui/lib/index.js"></script>
  <!-- 引入Echarts库 -->
  <script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.2.2/echarts.min.js"></script>
</head>
<body>
  <div id="app">
    <!-- 用于展示Echarts折线图的div -->
    <div id="line-chart" style="width: 100%; height: 800px;"></div>
    <!-- 播放、暂停按钮 -->
    <el-button type="primary" @click="startPlay">播放</el-button>
    <el-button type="success" @click="stopPlay">暂停</el-button>
    <el-select v-model="speed" placeholder="请选择播放速度">
      <el-option label="1.0x" :value="1000 / 1"></el-option>
      <el-option label="2.0x" :value="1000 / 2"></el-option>
      <el-option label="3.0x" :value="1000 / 3"></el-option>
      <el-option label="4.0x" :value="1000 / 4"></el-option>
    </el-select>
  </div>
</body>
</html>
<script type="text/javascript">
  new Vue({
    el: '#app',
    data: function () {
      return {
        myChart: null, // Echarts实例
        timer: null, // 定时器
        speed: 1000, // 播放速度,单位ms
        // 折线图数据
        data: [10, 52, 200, 334, 390, 330, 220,10, 52, 200, 334, 390, 330, 220],
        // x轴数据
        xData: ['周一', '周二', '周三', '周四', '周五', '周六', '周日', '周一', '周二', '周三', '周四', '周五', '周六', '周日'],
        newData: [], // 新的y轴数据
        newXData: [], // 新的x轴数据
        currentIndex: 0 //  // 定义一个变量保存当前播放到的点
      }
    },
    mounted() {
      this.initChart()
    },
    methods: {
      // 初始化
      initChart() {
        // 初始化Echarts
        this.myChart = echarts.init(document.getElementById('line-chart'));
        // 绘制折线图
        this.myChart.setOption({
          xAxis: {
            type: 'category',
            data: this.xData
          },
          yAxis: {
            type: 'value'
          },
          series: [{
            type: 'line',
            data: this.data
          }]
        });
        let that = this
        // 监听浏览器变化,使图表大小也随之变化
        window.addEventListener('resize', function () {
          that.myChart.resize()
        })
      },
      // 播放
      startPlay() {
        let that = this
        // 开启定时器
        this.timer = setInterval(function () {
          // 将第一个数据作为初识播放的点
          that.newData.push(that.data[that.currentIndex]);
          that.newXData.push(that.xData[that.currentIndex])
          // 如果当前点已经是最后一个,就清除定时器和数据
          if (that.currentIndex > that.xData.length - 1) {
            clearInterval(that.timer);
            that.$message.success('完成')
            that.currentIndex = 0
            that.newXData = []
            that.newData = []
            return;
          }
          // // 更新每个点的数值
          that.myChart.setOption({
            xAxis: {
              type: 'category',
              data: that.newXData
            },
            yAxis: {
              type: 'value'
            },
            series: [{
              type: 'line',
              data: that.newData
            }]
          });
          that.currentIndex++;
        }, this.speed);
      },
      // 暂停
      stopPlay() {
        clearInterval(this.timer);
      }
    }
  })
</script>


目录
相关文章
|
30天前
|
JSON JavaScript 定位技术
vue中使用echarts实现省市地图绘制,根据数据显示省市天气图标及温度信息
vue中使用echarts实现省市地图绘制,根据数据显示省市天气图标及温度信息
127 1
|
1月前
|
JavaScript API
vue尚品汇商城项目-day04【24.点击搜索按钮跳转后的页面商品列表、平台售卖属性动态展示(开发Search组件)】
vue尚品汇商城项目-day04【24.点击搜索按钮跳转后的页面商品列表、平台售卖属性动态展示(开发Search组件)】
53 1
vue尚品汇商城项目-day04【24.点击搜索按钮跳转后的页面商品列表、平台售卖属性动态展示(开发Search组件)】
|
1月前
|
算法 Java Linux
java制作海报五:java 后端整合 echarts 画出 折线图,项目放在linux上,echarts图上不显示中文,显示方框口口口
这篇文章介绍了如何在Java后端整合ECharts库来绘制折线图,并讨论了在Linux环境下ECharts图表中文显示问题。
39 1
|
30天前
|
JavaScript
vue中使用echarts绘制双Y轴图表时,刻度没有对齐的两种解决方法
vue中使用echarts绘制双Y轴图表时,刻度没有对齐的两种解决方法
203 0
|
30天前
|
JSON JavaScript 前端开发
vue中使用echarts实现省市地图绘制,根据数据在地图上显示柱状图信息,增加涟漪特效动画效果
vue中使用echarts实现省市地图绘制,根据数据在地图上显示柱状图信息,增加涟漪特效动画效果
370 0
|
30天前
|
JSON JavaScript 定位技术
Vue结合ECharts绘制省市地图:数据驱动区域颜色展示,支持省市下钻与经纬度打点功能
Vue结合ECharts绘制省市地图:数据驱动区域颜色展示,支持省市下钻与经纬度打点功能
76 0
|
1月前
|
小程序 前端开发 JavaScript
微信小程序图表制作利器:ECharts组件的使用与技巧
微信小程序图表制作利器:ECharts组件的使用与技巧
52 1
|
2月前
|
Web App开发 数据可视化 前端开发
Echart的使用初体验,Echarts的基本使用及语法格式,简单图表绘制和使用及图例添加【学习笔记】
本文介绍了ECharts的基本使用和语法格式,包括如何引入ECharts、创建容器、初始化echarts实例对象、配置option参数和一些基础图表的绘制方法。文章还提供了简单图表绘制和使用图例添加的示例代码,以及对ECharts特性和优势的概述。
Echart的使用初体验,Echarts的基本使用及语法格式,简单图表绘制和使用及图例添加【学习笔记】
|
3月前
|
小程序 JavaScript
微信小程序使用echarts图表(ec-canvas)
这篇文章介绍了在微信小程序中使用`ec-canvas`集成echarts图表的方法,包括解决加载时报错的问题、配置图表组件、以及在小程序页面中引入和使用这些图表组件的步骤。
461 1
微信小程序使用echarts图表(ec-canvas)
|
3月前
|
前端开发 数据可视化 JavaScript
Echarts如何实现多图表缩放和自适应?附源码
Echarts如何实现多图表缩放和自适应?附源码
Echarts如何实现多图表缩放和自适应?附源码