时间:2021-05-18
1.全局绑定滚轮事件,获得dataZoom最新的位置:
myChart.on('dataZoom',function(event){ if(event.batch){ start=event.batch[0].start; end=event.batch[0].end; }else{ start=event.start; end=event.end; };});2.把最新的start和end赋值给要更新的option
window.setInterval(function () { num=Math.random()*num+100; data0.splice(0,1); data0.push(num); option.dataZoom[0].start=start; option.dataZoom[0].end=end; myChart.setOption(option); },3000);3.echart数据增量刷新还可以用appendData
补充知识:echarts动态添加数据
我就废话不多说了,大家还是直接看代码吧~
<template> <!--为echarts准备一个具备大小的容器dom--> <div id="main" style="width: 600px;height: 400px;"></div></template><script> import echarts from 'echarts' export default { name: 'Chart', data () { return { charts: '', } }, methods:{ initLine(id){ this.charts = echarts.init(document.getElementById(id)) this.charts.setOption({ title: { text: '动态数据 + 时间坐标轴' }, tooltip: { trigger: 'axis', formatter: function (params) { params = params[0] return params.value[0] + ' : ' + params.value[1] }, axisPointer: { animation: false } }, xAxis: { type: 'time', splitLine: { show: false } }, yAxis: { type: 'value', boundaryGap: [0, '100%'], splitLine: { show: false } }, animation: false }) } }, mounted(){ this.$nextTick(function() { this.initLine('main') this.charts.setOption({ series : [ { name : '模拟数据0', type : 'line', showSymbol : false, hoverAnimation : false, data : [['2018-01-02', '3'],['2018-01-05', '4']] } ] }) setTimeout(() => { this.charts.appendData({ seriesIndex:0, data : [['2018-01-03', '1'],['2018-01-07', '2']] }) },2000) setTimeout(() => { this.charts.resize(); },4000) setTimeout(() => { this.charts.setOption({ series : [ {}, { name : '模拟数据1', type : 'line', showSymbol : false, hoverAnimation : false, data : [['2018-01-02', '5'],['2018-01-05', '10']] } ] }) this.charts.appendData({ seriesIndex:1, data : [['2018-01-03', '11'],['2018-01-10', '2']] }) },6000) setTimeout(() => { this.charts.resize(); },8000) }) } }</script><style scoped> * { margin: 0; padding: 0; list-style: none; }</style>补充
主动使用echarts的resize方法改变图表大小:
(opts?: { width?: number|string, height?: number|string, silent?: boolean})当在参数中填入宽高,this.echarts.resize({width:300}),dom层必须有一个初始化像素的宽高,百分比的宽高该方法不会生效。
以上这篇解决echarts echarts数据动态更新和dataZoom被重置问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言最近在学习eCharts,学习到了异步更新和数据加载这一块,觉着有必要总结一下,方法以后的时候参考学习,在开始本文之前,对eCharts不熟悉的朋友们可以参
Echarts是由百度提供的数据可视化解决方案,可以让我们快速实现功能丰富的图表,官网链接使用方法1.引入echarts.min.js文件下载echarts.m
微信小程序使用echarts,实现左右双Y轴,动态获取数据,生成折线图本来使用的是wxcharts,但发现实现不了左右双y轴的效果,就换成echarts要实现这
pyecharts介绍pyecharts是一个用于生成Echarts图表的类库。Echarts是百度开源的一个数据可视化JS库。用Echarts生成的图可视化效
环境:pyecharts库,echarts-countries-pypkg,echarts-china-provinces-pypkg,echarts-chin