ECharts实现数据可视化入门详解

文章目录

  • ECharts实现数据可视化入门详解
    • 一、引言
    • 二、基础配置
      • 1.1、代码示例
    • 三、动态数据与交互
      • 2.1、代码示例
    • 四、高级用法
      • 1、多图表组合
        • 1.1、在同一容器中绘制多个图表
        • 1.2、创建多个容器并分别初始化 ECharts 实例
        • 1.3、实现多图联动
    • 五、总结

ECharts实现数据可视化入门详解

一、引言

ECharts 是一个使用 JavaScript 实现的开源可视化库,它提供了丰富的图表类型和交互功能,方便开发者将数据转化为直观、可交互的图表形式。本篇博客将详细介绍如何使用 ECharts 进行数据可视化的入门操作,包括基础配置、动态数据与交互以及高级用法。
在这里插入图片描述

二、基础配置

ECharts 的配置项非常丰富,以下是一些常用的配置项:

  • title:图表标题。
  • tooltip:提示框组件。
  • legend:图例组件。
  • xAxis/yAxis:坐标轴配置。
  • series:系列列表,每个系列通过 type 决定图表类型。

1.1、代码示例

下面是一个简单的 ECharts 柱状图示例:
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>ECharts 入门示例</title><style>.box{width: 600px;height: 400px;background-color: rgb(188, 227, 236);}</style>
</head>
<body><div class="box"></div><script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script><script>var myChart = echarts.init(document.querySelector(".box"));var option = {title: {text: 'ECharts 入门示例'},tooltip: {},legend: {data:['销量']},xAxis: {data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]},yAxis: {},series: [{name: '销量',type: 'bar',data: [5, 20, 36, 10, 10, 20]}]};myChart.setOption(option);</script>
</body>
</html>

三、动态数据与交互

ECharts 不仅支持静态数据展示,还可以实现动态数据更新和交互操作。通过 setOption 方法更新配置项,可以实现数据的动态更新。同时,ECharts 提供了丰富的交互功能,如数据缩放、工具箱等。

2.1、代码示例

下面是一个动态更新数据的 ECharts 示例:

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>动态数据更新示例</title><script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script>
</head>
<body><div id="container" style="width: 600px;height:400px;"></div><script type="text/javascript">var myChart = echarts.init(document.getElementById('container'));var option = {// ... 基础配置项};myChart.setOption(option);// 模拟动态数据更新setInterval(function () {var data = option.series[0].data;data.shift();data.push(Math.round(Math.random() * 100));myChart.setOption({series: [{data: data}]});}, 2000);</script>
</body>
</html>

四、高级用法

1、多图表组合

ECharts 支持在同一个页面中展示多个图表,实现复杂的数据可视化效果。这可以通过以下几种方式实现:

1.1、在同一容器中绘制多个图表

我们可以在一个容器中使用 ECharts 的 grid 配置项来布局多个图表。这种方式适用于需要在有限空间内展示多个相关图表的场景。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>多图表组合示例</title><style>.chart {width: 1500px;}</style>
</head>
<body><div id="app"><div id="main" class="chart"></div></div><script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script><script type="text/javascript">var myChart = echarts.init(document.getElementById("main"));var option = {// 配置多个图表的 grid 布局grid: [{ left: '10%', top: '10%', width: '40%', height: '30%' },{ right: '10%', top: '10%', width: '40%', height: '30%' },{ left: '10%', top: '50%', width: '40%', height: '30%' },{ right: '10%', top: '50%', width: '40%', height: '30%' }],// 配置多个图表的标题、工具箱等title: [{ text: '图表1', left: '15%', top: '10%' },{ text: '图表2', right: '15%', top: '10%' },{ text: '图表3', left: '15%', top: '50%' },{ text: '图表4', right: '15%', top: '50%' }],// 其他配置项...};myChart.setOption(option);</script>
</body>
</html>
1.2、创建多个容器并分别初始化 ECharts 实例

另一种方式是为每个图表创建独立的容器,并分别初始化 ECharts 实例。这种方式适用于需要独立操作和展示的图表。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>多个独立图表示例</title><style>.chart {width: 600px;height: 400px;margin: 10px;}</style>
</head>
<body><div id="chart1" class="chart"></div><div id="chart2" class="chart"></div><div id="chart3" class="chart"></div><div id="chart4" class="chart"></div><script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script><script type="text/javascript">var chart1 = echarts.init(document.getElementById('chart1'));var chart2 = echarts.init(document.getElementById('chart2'));var chart3 = echarts.init(document.getElementById('chart3'));var chart4 = echarts.init(document.getElementById('chart4'));// 为每个图表设置不同的配置项和数据chart1.setOption(option1);chart2.setOption(option2);chart3.setOption(option3);chart4.setOption(option4);</script>
</body>
</html>
1.3、实现多图联动

ECharts 还支持多图联动,即一个图表的变化能够实时反映到其他图表中。这可以通过 echarts.connect 方法实现。

// 假设 chart1, chart2 是两个已经初始化的 ECharts 实例
echarts.connect([chart1, chart2]);

通过上述方法,我们可以在同一个页面中灵活地展示多个图表,并实现它们之间的联动和交互。这种方式极大地增强了数据可视化的灵活性和表现力。

五、总结

ECharts 是一个功能强大的数据可视化工具,通过简单的配置和代码示例,我们可以快速入门并实现基本的数据可视化需求。随着对 ECharts 更深入的学习和实践,我们可以探索更多的图表类型和交互功能,以满足更复杂的业务场景。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • ECharts 教程 | 菜鸟教程
  • ECharts实现数据可视化入门详解_echarts详细教程-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/64316.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

盲盒3.0版h5版-可打包app-新优化版紫色版

整体界面ui美观大气&#xff0c;盲盒项目也是一直比较热门的&#xff0c;各大平台一直自己也有做。 感兴趣的小伙伴可以搭建做自己的项目。盲盒项目的利润率还是很大的。

MacbookPro M1 安装Hive

前提注意⚠️⚠️⚠️ 1&#xff09;在安装Hive前确实需要安装MySQL&#xff0c;因为Hive可以使用MySQL作为元数据存储 2&#xff09;在安装Hive之前&#xff0c;需要先安装Hadoop。Hive是一个构建在Hadoop之上的数据仓库软件&#xff0c;它使用Hadoop的HDFS&#xff08;分布…

Crawl4AI:一个为大型语言模型(LLM)和AI应用设计的网页爬虫和数据提取工具实战

这里写目录标题 一、crawl4AI功能及简介1、简介2、特性 二、项目地址三、环境安装四、大模型申请五、代码示例1.生成markdown2.结构化数据 一、crawl4AI功能及简介 1、简介 Crawl4AI 是一个开源的网页爬虫和数据抓取工具&#xff0c;一个python项目&#xff0c;主要为大型语言…

游戏引擎学习第50天

仓库: https://gitee.com/mrxiao_com/2d_game Minkowski 这个算法有点懵逼 回顾 基本上&#xff0c;现在我们所处的阶段是&#xff0c;回顾最初的代码&#xff0c;我们正在讨论我们希望在引擎中实现的所有功能。我们正在做的版本是初步的、粗略的版本&#xff0c;涵盖我们认…

深度解读:Top14金融顶刊

作者Toby&#xff1a;来源&#xff1a;Python风控模型&#xff0c;Top14金融顶刊 各位同学好&#xff0c;我是Toby老师&#xff0c;今天为大家介绍金融风控领域的顶级学术期刊&#xff0c;用于小论文发布平台参考。 金融风控领域内有许多顶级学术期刊&#xff0c;它们发表高质…

数据库管理-第271期 Oracle 23ai:用MongoDB的方式来操作JSON二元性(20241214)

数据库管理271期 2024-12-14 数据库管理-第271期 Oracle 23ai&#xff1a;用MongoDB的方式来操作JSON二元性&#xff08;20241214&#xff09;1 初始化数据1.1 创建用户1.2 导入数据1.3 创建JSON关系二元性视图 2 创建ORDS服务2.1 下载JDK172.2 安装ORDS2.3 启用MongoDB API2.4…

计网_虚拟局域网VLAN

2024.12.08&#xff1a;计算机网络虚拟局域网VLAN学习笔记 虚拟局域网VLAN VLAN背景&#xff08;认真看&#xff09;VLAN定义&#xff08;最大的好处是隔离广播域&#xff09;VLAN以太网帧格式的扩展划分虚拟局域网VLAN的方式虚拟局域网的优点 VLAN背景&#xff08;认真看&…

使用ENSP实现NAT(2)

一、NAT的类型 二、静态NAT 1.项目拓扑 2.项目实现 路由器AR1配置&#xff1a; 进入系统视图 sys将路由器命名为AR1 sysname AR1关闭信息中心 undo info-center enable 进入g0/0/0接口 int g0/0/0将g0/0/0接口IP地址配置为192.168.10.254/24 ip address 192.168.10.254 24进…

Oracle PDB的开启和关闭

[生产环境关闭与开启Oracle PDB] 【运维场景】 在运维Oracle PDB的时候经常要开启和关闭PDB&#xff0c;对关闭和开启PDB的操作要非常熟悉。 【操作方法】 1. PDB的打开与关闭 关闭和开启DB的时候要看DB的警告日志&#xff0c;日志位置&#xff08;在Oracle用户下查看&…

【树莓派4B】MindSpore lite 部署demo

一个demo&#xff0c;mindspore lite 部署在树莓派4B ubuntu22.04中&#xff0c;为后续操作开个门&#xff01; 环境 开发环境&#xff1a;wsl-ubuntu22.04分发版部署环境&#xff1a;树莓派4B&#xff0c;操作系统为ubuntu22.04mindspore lite版本&#xff1a;mindspore-li…

第17天:信息收集-Web应用备案产权Whois反查域名枚举DNS记录证书特征相似查询

#知识点 1、信息收集-Web应用-机构产权&域名相关性 2、信息收集-Web应用-DNS&证书&枚举子域名 标签 名称 地址 企业信息 天眼查 天眼查-商业查询平台_企业信息查询_公司查询_工商查询_企业信用信息系统 企业信息 小蓝本 获客营销系统_ai智能拓客系统_企业获…

在循环群模运算中计算逆元

文章目录 一、算数模复合二、群 循环群1. 群 (Group)2. 环 (Ring)3. 循环群 (Cyclic Group)4. 多项式环 (Polynomial Ring)5. 有限域 (Finite Field)6. 椭圆曲线 (Elliptic Curve) 三、求逆元1. 扩展欧几里得算法1.1 算法概述1.2 步骤1.3 示例 2. 费马小定理 一、算数模复合 假…

Python使用Selenium库获取 网页节点元素、名称、内容的方法

我们要用到一些网页源码信息&#xff0c;例如获取一些节点的class内容&#xff0c; 除了使用Beautifulsoup来解析&#xff0c;还可以直接用Selenium库打印节点&#xff08;元素&#xff09;名称&#xff0c;用来获取元素的文本内容或者标签名。 例如获取下面的class的内容&am…

M3DM的autodl环境构建过程笔记

文章目录 在3D-ADS环境https://blog.csdn.net/tfxzgp/article/details/144259472基础上构建M3DM(失败的记录&#xff0c;不用看)更换镜像重来&#xff08;成功&#xff09;安装缺少的包修改models.py中的RGB和点云backbone的路径修改main.py路径参数运行 在3D-ADS环境https://b…

Android 使用Overlay现实主题切换

最近项目上&#xff0c;想做一个主题切换的功能&#xff0c;整理了一下发布出来&#xff0c;主要使用的是IOverlayManager&#xff0c;大体思路如下&#xff1a; 1、想切换的应用&#xff0c;各自做overlay apk&#xff08;简称皮肤包&#xff09; 2、将overlay apk push 到v…

【原生js案例】如何实现一个穿透字体颜色的导航

普通的导航大家都会做&#xff0c;像这种穿透字体的导航应该很少见吧。高亮不是通过单独设置一个active类来设置字体高亮颜色&#xff0c;鼠标滑过导航项&#xff0c;字体可以部分是黑色&#xff0c;不分是白色&#xff0c;这种效果的实现 感兴趣的可以关注下我的系列课程【we…

IDEA 2023.3.6 下载、安装、激活与使用

一、IDEA2023.3.6下载 国际官网&#xff1a;https://www.jetbrains.com/ 国内官网&#xff1a;https://www.jetbrains.com.cn/ 如果国际官网无法访问&#xff0c;就使用国内官网&#xff0c;我们以国内官网为例下载IDEA2023.3.6 首先进入首页如下图&#xf…

ip_done

文章目录 路由结论 IP分片 数据链路层重谈Mac地址MAC帧报头局域网的通信原理MSS&#xff0c;以及MAC帧对上层的影响ARP协议 1.公司是不是这样呢? 类似的要给运营商交钱&#xff0c;构建公司的子网&#xff0c;具有公司级别的入口路由器 2&#xff0e;为什么要这样呢?? IP地…

深度学习作业 - 作业十一 - LSTM

问题一 推导LSTM网络中参数的梯度&#xff0c;并的分析其避免梯度消失的效果 LSTM网络是为了解简单RNN中存在的长程依赖问题而提出的一种新型网络结构&#xff0c;其主要思想是通过引入门控机制来控制数据的流通&#xff0c;门控机制包括输入门、遗忘门与输出门&#xff0c;同…

医院与医疗设备供应商网络安全事故综述

医院与医疗设备供应商网络安全事故综述 在医疗行业中&#xff0c;医院和医疗设备供应商的网络安全问题同样不容忽视。以下是一些近年来发生的重大网络安全事故的总结&#xff1a; 1. 德国杜塞尔多夫大学医院勒索软件攻击&#xff08;2020年&#xff09; 事件描述&#xff1a…