vue中使用echarts实现动态图表多数据展示,带源码(x轴动态时间刷新,实时更新展示数据)

简介: 之前写项目,需要写一个图表动态展示出当前服务器的信息,在网上找了很多相关的文章,但是关于vue中使用echarts动态图表的内容比较少,自己写过之后就在这里记录一下,希望能够对大家有所帮助

前言

之前写项目,需要写一个图表动态展示出当前服务器的信息,在网上找了很多相关的文章,但是关于vue中使用echarts动态图表的内容比较少,自己写过之后就在这里记录一下,希望能够对大家有所帮助

实现效果

先来看下效果:
动态展现当前服务器 内存占用率,cpu占用率,磁盘写入量和磁盘读取量(因为服务器没上东西,所以数据相对比较平缓),下面教大家怎么写出这种动态图表
在这里插入图片描述

option的内容

首先对于这样一个动态图表,看起来很复杂,因为我这里有四条数据,大家可以先写一条数据,把他跑起来,其余再加数据是很容易的:
这里option的数据,要注意的点:

  1. xAxis存放横坐标的数据,我这里是实时展示当前时间刷新出来,先给data:[ ],后面再处理
  2. yAxis存放纵坐标数据,这里是写死的,应该没啥问题,两个对象对应左右两个纵坐标
  3. series存放当前图表的数据,四条数据所以是四个对象,data数组都给空,因为这里进行动态渲染
option: {
  tooltip: {
    trigger: 'axis',
    axisPointer: { type: 'cross' }
  },
  legend: {
  },
  xAxis: [
    {
      type: 'category',
      axisTick: {
        alignWithLabel: true,
        show: false
      },
      data: []
    }
  ],
  yAxis: [
    {
      type: 'value',
      name: '磁盘使用量',
      min: 0,
      max: 1000,
      position: 'right',
      axisLabel: {
        formatter: '{value} GB'
      }
    },
    {
      type: 'value',
      name: '占用百分比',
      min: 0,
      max: 100,
      position: 'left',
      axisLabel: {
        formatter: '{value} %'
      }
    }
  ],
  series: [
    {
      name: '内存占用率',
      yAxisIndex: 1,
      type: 'bar',
      data: [],
      itemStyle: {
        barBorderRadius: 5,
        borderWidth: 1,
        borderType: 'solid',
        borderColor: '#73c0de',
        shadowColor: '#5470c6',
        shadowBlur: 1
      }
    },
    {
      name: 'CPU占用率',
      yAxisIndex: 1,
      type: 'bar',
      data: [],
      itemStyle: {
        barBorderRadius: 5,
        borderWidth: 1,
        borderType: 'solid',
        borderColor: '#73c0de',
        shadowColor: '#5470c6',
        shadowBlur: 1
      }
    },
    {
      name: '磁盘写入量',
      yAxisIndex: 0,
      type: 'line',
      data: []
    },
    {
      name: '磁盘读取量',
      yAxisIndex: 0,
      type: 'line',
      data: []
    }
  ]
}

函数内容

说明:因为实际开发的运用场景可能不同,所以方法上存在差异,我这里是写成一个组件,数据由父组件传入,不过主要的大致思路相同,看懂下面我讲的,基本你自己能够复现

下面我讲解的顺序,按照页面声明周期的顺序走:

1.created()

页面穿建阶段,为了避免图表创建出来是空的,没有数据,所以我这里的处理是:获取当前时间前20个数据,这样图表刷新出来的时候,里面是有数据的,然后再删数据,加新数据

所以created中我写了获取前二十个数据的函数:

created () {
    this.getbefortime()
},

获取前20个数据,实际开发就得找后端写这个接口,前端直接调用,然后我将前20个数据存入beforinfo中

// 获取前20个数据
async getbefortime() {
  const { data: res } = await serverCpubefor()
 

  this.beforinfo = res
  // console.log('******', this.beforinfo)
},

前20个数据获取好了,那就还需要获取前二十个时间,也就是横坐标:这里思路就是我每隔3s刷新一次,就获取当前时间,然后往后推20个3s,每个数据都存入到xAxis的data中,并且也把刚刚获取的前20个数据存入series对应的data中

//获取前20个时间,并把前20个时间,和前20个数据存入对应的xAxis和series的data中,这样图表生成就有数据
addbeforData() {
   var hh = new Date().getHours();
   var mf = new Date().getMinutes()<10 ? '0'+new Date().getMinutes() : new Date().getMinutes();
   var ss = new Date().getSeconds()<10 ? '0'+new Date().getSeconds() : new Date().getSeconds();
   for(var i=0;i<=19;i++){
     if(ss>12){
       ss=ss-3
     }else if(12<=ss>=3){
       ss='0'+(ss-3)
     }else{
       if(mf>=11){
         mf=mf-1
         ss=60-3
       }else{
         mf='0'+(mf-1)
         ss=60-3
       }
     }
     var befortime = [hh, mf, ss].join(":");
     // console.log('---***---',befortime )
     // console.log('---***---',this.beforinfo.数据[i].CPU占用率[0] )
     this.option.xAxis[0].data.unshift(befortime);
     // 添加初始cpu占用率数据
     this.option.series[1].data.unshift(this.beforinfo.数据[i].CPU占用率[0]);
     // 添加初始内存占用率数据
     this.option.series[0].data.unshift(this.beforinfo.数据[i].内存占用率[0]);
     // 添加初始磁盘写入量数据
     this.option.series[2].data.unshift(this.beforinfo.数据[i].硬盘写入量[0]);
     // 添加初始磁盘读取量数据
     this.option.series[3].data.unshift(this.beforinfo.数据[i].硬盘读取量[0]);
     //console.log(befortime)
   }
  
 },

created后我们需要在mouted中初始化图表:
使用myChart.showLoading()实现加载的效果

mounted() {
    let myChart = echarts.init(document.getElementById("main2"))
    myChart.showLoading();
  },

2.图表生成

上面我们写了addbeforData()函数,那么在哪里调用呢?这里就要用到watch进行监听,this.beforinfo初始值为空,我们在获取到前20个数据的时候将值存入了this.beforinfo中,所以只要beforinfo值发生了改变,就可以进行addbeforData()函数和生成图表了:

//监听beforinfo值的变化
watch: {
    beforinfo(newVal,oldVal){
      this.addbeforData()
      this.initchart()
    }
  },

initchart函数就是我们生成图表的函数:
到这一步说明图表数据以及没问题了,可以展示图表了,myChart.hideLoading()关闭加载的动画

initchart(){
  let myChart = echarts.getInstanceByDom(document.getElementById("main2"));
  myChart.hideLoading();
  myChart.setOption(this.option);
  window.addEventListener('resize', function () {
    myChart.resize()
  })
}

3.数据的动态渲染

到上面一步,图表就已经生成了,只不过里面展示的是当前时间的前20个数据,那么我们还需要图动起来,下面就来进行动态渲染:
首先写一个gettime()函数来获取当前的时间并返回

gettime(){
  var hh = new Date().getHours();
  var mf = new Date().getMinutes()<10 ? '0'+new Date().getMinutes() : new Date().getMinutes();
  var ss = new Date().getSeconds()<10 ? '0'+new Date().getSeconds() : new Date().getSeconds();
  var nowtime = [hh, mf, ss].join(":");
  return nowtime
},

然后我们还是使用watch进行监听,我这里的值是由父组件msg传过来的,所以只要msg值发生改变就说明有新的数据,那么就要进行新数据的加入和旧数据的删除,从而实现动态效果:
别忘了删除和添加数据之后要重新调用this.initchart()实现图表的刷新

//在watch中监听msg数据
msg(val) {
  this.serverInfo = val
  if(this.option.series[1].data.length == '20' ) {
    // 删除头部数据
    this.option.xAxis[0].data.shift();
    this.option.series[1].data.shift();
    this.option.series[0].data.shift();
    this.option.series[2].data.shift();
    this.option.series[3].data.shift();

    // 队尾添加数据
    this.option.xAxis[0].data.push(this.gettime());
    this.option.series[1].data.push(this.serverInfo.数据.CPU占用率[0]);
    this.option.series[0].data.push(this.serverInfo.数据.内存占用率[0]);
    this.option.series[2].data.push(this.serverInfo.数据.硬盘写入量[0]);
    this.option.series[3].data.push(this.serverInfo.数据.硬盘读取量[0]);
  }
  this.initchart()
},

==可能对于动态数据这里大家可能有疑问,因为我这里数据是从父组件传过来的,没有写在这个页面,我把父组件的实现关键点给大家看看:==
父组件中的函数:
1.getCputhings()获取到当前的数据,存入到this.serverInfo中,这就是把这个值传给子组件也就是上面图表
2.在mounted中使用setInterval定时器,每隔几秒就请求一次数据,所以子组件只要监听到传过去的数据改变就能渲染最新的数据
3.beforeDestroy()中删除掉这个定时器,避免进入其它页面,定时器依旧在工作

methods: {
    async getCputhings() {
      const { data: res} = await serverCpu()
      this.serverInfo = res
    },
  },
  created() {
    this.getCputhings()
  },
  mounted() {
    
    this.timer = window.setInterval(() => {
      setTimeout(()=>{
        this.getCputhings()
      })
    }, 2000)
  },
  beforeDestroy() {
    clearInterval(this.timer)
  }

最后

这样一套下来,就能实现出图表的动态渲染,主要是这样一个监听渲染的过程,对于图表样式可以根据自己的想法来,换汤不换药罢了

在这里插入图片描述
如果对你有帮助,点赞 点个关注支持一下,有问题可以在评论区留言~
如果需要页面完整代码的评论区留言,主要代码上面都有,因为篇幅原因这里就不放了
在这里插入图片描述

相关文章
|
3月前
|
JSON JavaScript 定位技术
vue中使用echarts实现省市地图绘制,根据数据显示省市天气图标及温度信息
vue中使用echarts实现省市地图绘制,根据数据显示省市天气图标及温度信息
432 1
|
3月前
|
JavaScript
vue中使用echarts绘制双Y轴图表时,刻度没有对齐的两种解决方法
vue中使用echarts绘制双Y轴图表时,刻度没有对齐的两种解决方法
754 0
|
3月前
|
JSON JavaScript 前端开发
vue中使用echarts实现省市地图绘制,根据数据在地图上显示柱状图信息,增加涟漪特效动画效果
vue中使用echarts实现省市地图绘制,根据数据在地图上显示柱状图信息,增加涟漪特效动画效果
930 0
|
3月前
|
JSON JavaScript 定位技术
Vue结合ECharts绘制省市地图:数据驱动区域颜色展示,支持省市下钻与经纬度打点功能
Vue结合ECharts绘制省市地图:数据驱动区域颜色展示,支持省市下钻与经纬度打点功能
286 0
|
20天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
109 1
|
30天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
55 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
51 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
45 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
38 1
vue学习第7章(循环)