怎么在echarts图上左右滑动切换数据区间

2023-11-21 05:12

本文主要是介绍怎么在echarts图上左右滑动切换数据区间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说在前面

不管前端还是后端,大家或多或少都了解使用过echarts图表吧,很多时候我们只是需要展示指定区间的数据,但有时我们希望在图表上能够轻松地切换数据的展示区间,以便更清晰地观察特定时间段或区域的变化。在本文中,我将向大家介绍如何实现在 ECharts 图表上左右滑动切换数据区间的功能,让数据展示交互变得更加灵活。

效果展示

echarts滑动.gif

体验地址

http://jyeontu.xyz/JDemo/#/echartScroll

代码实现

1、了解一下echarts.getZr()

在 ECharts 中,getZr() 是一个常用的方法,它可以获取到 ECharts 实例中的 ZRender 实例。

首先,需要说明的是,ECharts 中的图表实现都依赖于一个开源的 2D 渲染引擎 ZRender,而 getZr() 方法就是用于获取该渲染引擎实例。

在 ECharts 中,我们可以通过以下方式来获取 ECharts 实例:

var myChart = echarts.init(dom);

在这个实例对象中,就包含了我们所需要的 getZr() 方法。

接下来,我们可以通过 myChart.getZr() 来获取到 ZRender 实例,并利用其提供的 API 进行一些自定义的操作,例如:

var zr = myChart.getZr();
var storage = zr.storage;
var group = new zrender.Group();
storage.add(group);var rect = new zrender.Rect({shape: {x: 10,y: 10,width: 100,height: 100},style: {fill: '#f00'}
});group.add(rect);zr.refresh();

在上面的代码中,我们首先通过 getZr() 方法获取到 ZRender 实例,并创建了一个新的 Group 对象,并向其中添加了一个矩形 Rect 对象。最后我们调用了 refresh() 方法来刷新渲染界面,使我们新创建的矩形能够显示在图表上。

总之,getZr() 方法为我们提供了更多自定义 ECharts 图表的可能性,例如添加自定义的图形、动画等效果

2、echarts.getZr().on(eventType, handler)

getZr().on(eventType, handler) 是在 ECharts 中用于监听 ZRender 实例上指定事件类型的方法。它允许我们在特定的事件发生时执行相应的处理函数。

具体使用方法如下:

  1. 通过 getZr() 方法获取到 ZRender 实例,例如 const zr = myChart.getZr();
  2. 使用 on() 方法来监听指定的事件类型和相应的处理函数,例如 zr.on('click', handleClick);。其中,eventType 为事件类型,可以是鼠标事件(如 clickmousemove 等),也可以是自定义事件;handler 则是事件触发时要执行的处理函数。
  3. 在处理函数中编写相应的逻辑,例如:
function handleClick(params) {// 处理鼠标点击事件console.log('Clicked at x: ' + params.event.clientX + ', y: ' + params.event.clientY);
}

在上述代码中,当用户在图表上点击时,handleClick 函数会被调用,并且参数 params 中包含了事件的相关信息,例如鼠标坐标等。

通过 getZr().on() 方法,我们可以实现对图表的交互操作进行监听和响应,从而实现更加丰富和灵活的数据可视化效果。

3、echarts鼠标事件监听

通过前面的介绍,我们知道可以通过echarts.getZr().on(eventType, handler)来对图表的交互操作进行监听和响应:

(1)监听touchstart事件或mousedown事件,记录起始位置

监听touchstart事件或mousedown事件,记录起始位置,并将当前状态置为滑动状态。

myEcharts.getZr().on("mousedown", e => {this.lastX = e.offsetX || e.event.zrX;this.isTouch = true;
});
myEcharts.getZr().on("touchstart", e => {this.lastX = e.offsetX || e.event.zrX;this.isTouch = true;
});
(2)监听touchmove事件或mousemove事件,计算滑动距离并触发相应操作

这里我们需要注意的是,mousemovetouchmove都是连续触发的事件,所以我们需要对其加一个防抖处理,防止连续触发多次。

debounce(func, delay = 100) {let timer;return function(...args) {clearTimeout(timer);timer = setTimeout(() => {func.apply(this, args);}, delay);};
},
mousemove(e) {if (this.isTouch) {const currentX = e.offsetX || e.event.zrX;const distance = currentX - this.lastX;if (distance > this.distance) {this.$emit("moveRight");} else if (distance < -this.distance) {this.$emit("moveLeft");}this.lastX = currentX;}
},
myEcharts.getZr().on("mousemove", this.debounce(this.mousemove));
myEcharts.getZr().on("touchmove", this.debounce(this.mousemove));
(3)监听touchend事件或mouseup事件,重置状态

鼠标抬起的时候重置状态,防止鼠标没有点击的时候触发滑动事件。

myEcharts.getZr().on("mouseup", () => {this.isTouch = false;
});
myEcharts.getZr().on("touchend", () => {this.isTouch = false;
});

4、echarts数据生成

这里我们可以随机生成两个月的数据来进行展示:

initChartData(startDate, endDate) {startDate = new Date(startDate);endDate = new Date(endDate);const dateArray = [];for (let date = new Date(startDate);date <= endDate;date.setDate(date.getDate() + 1)) {const randomValue = Math.floor(Math.random() * (1000 - 500 + 1)) + 500;const randomValue1 = Math.floor(Math.random() * (1000 - 200 + 1)) + 200;const dateString = date.toISOString().slice(0, 10);dateArray.push({date: dateString,value: randomValue,value1: randomValue1});date = new Date(date); // 修复日期对象被修改的问题}return dateArray;
},

image.png

5、echarts数据配置

我们可以通过数据起始下标和展示数据个数来确定当前图表中需要展示的数据区间,再从总数据中去进行截取。

initOption(start = 0) {if (start > this.chartData.length - this.len)start = this.chartData.length - this.len;if (start < 0) start = 0;if (this.startInd === start) return;this.startInd = start;const end = start + this.len;const chartData = this.chartData.slice(start, end);this.option = {tooltip: {trigger: "axis"},xAxis: {type: "category",data: chartData.map(item => item.date)},yAxis: {type: "value"},series: [{name: "数据1",data: chartData.map(item => item.value),type: "line",smooth: true},{name: "数据2",data: chartData.map(item => item.value1),type: "line",smooth: true}]};
},

6、左右滑动切换数据区间

想要切换展示的数据区间,我们只需要修改数据起始下标即可:

moveLeft() {if (this.startInd === 0) this.$toast.show("前面没有更多数据了");this.initOption(this.startInd - this.len);
},
moveRight() {if (this.startInd >= this.chartData.length - this.len)this.$toast.show("后面没有更多数据了");this.initOption(this.startInd + this.len);
}

源码地址

gitee

https://gitee.com/zheng_yongtao/jyeontu-vue-demo.git

公众号

关注公众号『前端也能这么有趣』发送 vueDemo即可获取源码。

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

这篇关于怎么在echarts图上左右滑动切换数据区间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/400047

相关文章

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate

Oracle数据库如何切换登录用户(system和sys)

《Oracle数据库如何切换登录用户(system和sys)》文章介绍了如何使用SQL*Plus工具登录Oracle数据库的system用户,包括打开登录入口、输入用户名和口令、以及切换到sys用户的... 目录打开登录入口登录system用户总结打开登录入口win+R打开运行对话框,输php入:sqlp

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下