Echarts数据可视化教程(超详细,持续更新中....)

news/2024/11/19 10:43:20/

作者有话对你说在这里插入图片描述

随着前端的飞速发展,近年来数据可视化越来越火,有些公司的业务跟地图、位置、大数据等脱离不开关系,所以数据可视化甚至成了单独的一门前端行业,比如在杭州地区的前端可视化职位不但有一定的需求量且高薪,
因为是工作之余才有时间写文章,这篇文章已经停更了一段时间,其实有很多次想重新把这篇文章写完,考虑到有官方文档就一直没坚持更新这篇文章,不过看到仍然有很多人在看和关注这篇文章,我准备继续更新,更新可能都在晚上,觉得有用的可以先收藏,我会按时更新,学习成长的路上本就孤单,在之后的路上也希望大家多多支持和陪伴,我会尽我所能产出一些对大家有益的文章–前端初见2023/4/12

文章目录

  • 作者有话对你说![在这里插入图片描述](https://img-blog.csdnimg.cn/26dc72c830d9469ca5d3cc4f39fa9663.png#pic_center)
  • 前言
  • 一、Echarts的介绍?
  • 二、Echarts的快速入门
    • 2.1、Echarts的基本使用
        • 2.2、 Echarts配置项的使用
  • 三、Echarts的常用图表
        • 3.1 通用配置
          • 3.1.1、标题:title
          • 3.1.2、提示:tooltip
          • 3.1.3、工具按钮:toolbox
          • 3.1.4、图例:legend
        • 3.2、Echarts中的7大图表
          • 3.2.1、图表1:柱状图
            • Echarts中的柱形图的常见效果
          • 3.2.2、图表2:折线图
  • 总结
    • ==**持续更新中**==


前言

在这里插入图片描述
1.什么是数据可视化?

  • 把数据以图表(更直观)的形式展现 -->图表

2.数据可视化的好处

  • 清晰有效地传达与沟通信息
  • 更好的观察隐藏在数据中的信息

3.数据可视化的的实现方式

  • 报表类
    • Excel
    • 水晶报表
  • 商业智能BII
    • Microsoft BI
    • Power BI
  • 编码类(最佳灵活、门槛高)
    • Echarts.js
    • D3.js

一、Echarts的介绍?

Echarts是一个使用JavaScript实现的开源可视化库,兼容性强,底层依赖矢量图形库ZRender,提供直观,交互丰富,可高度 个性化定制的数据可视化图表。

  • Echarts能满足绝大多数可视化图表实现
    • 兼容性强
    • 使用方便
    • 功能强大
  • 实现数码可视化最佳选择之一

Echarts的特点

  • 开源免费 (遵循Apache-2.0开源协议,免费使用)

  • 功能丰富(涵盖各行业图表,满足各种需求)

  • 社区活跃

  • 移动端优化和跨平台使用

  • 绚丽的特效和三维可视化等等

  • 丰富的可视化类型

    • 折线图、柱状、饼图、k线图…
  • 多种数据格式支持

    • key-value数据格式
    • 二维表
    • TypedArray格式
  • 流数据的支持

    • 流数据的动态渲染
    • 增量渲染技术
  • 只有你想不到,没有它做不到,详情点击下方网址链接查阅

官网地址
在这里插入图片描述
Echarts特性介绍地址
在这里插入图片描述

二、Echarts的快速入门

2.1、Echarts的基本使用

获取 Apache ECharts

点击链接进入网页ctrl+s保存,即可下载echarts.js
也可 打开https://www.jsdelivr.com/package/npm/echarts 选择 dist/echarts.js,点击并保存为 echarts.js 文件。也可通过别的方式。别的方式可查看官方文档!
在这里插入图片描述

  • 步骤1:引入echarts.js文件
  • 步骤2:准备一个呈现图标的盒子
  • 步骤3:初始化echarts实例对象
  • 步骤4:准备配置项 (最重要、最麻烦)
  • 步骤5:将配置项设置给你echarts实例对象

代码如下(示例):

<!DOCTYPE html>
<html lang="en"><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>Document</title><!-- 步骤1:引入echarts.js文件 --><script src="lib/echarts.js"></script>
</head><body><!-- - 步骤2:准备一个呈现图标的盒子 --><div id="table1" style="width: 600px;height: 400px;background-color: antiquewhite;"></div><script>// 步骤3:初始化echarts实例对象// 参数,dom元素,决定图表最终呈现的位置var mCharts = echarts.init(document.querySelector('#table1'))// 步骤4:准备配置项 **(最重要、最麻烦)**var option={xAxis :{type:'category',data:['路飞','索隆','娜美']},yAxis :{type:'value'},series:[{name:'悬赏金',type:'bar',data:[92,80,72]}]}// 步骤5:将配置项设置给你echarts实例对象mCharts.setOption(option)</script>
</body></html>

完成这五步就可以得到一个图表
在这里插入图片描述

2.2、 Echarts配置项的使用

点击下方链接,进入Echarts官网配置项手册
Echarts官网配置项手册

  • 以上步骤,除了配置项会变化之外,其他的代码都是固定的
  • 配置项的学习和使用应该参照官方文案和示例

常用配置项

  • xAxis:直角坐标系中的x轴
  • yAxis:直角坐标系中的y轴
  • series:系列列表,每个系列列表通过type决定自己的图标类型(给y轴提供数据的)
  • title:主标题文本
  • link:主标题文本超链接
  • textStyle主标题文本的样式
    代码如下(示例):
  var option = {title: {// 主标题文本text: '海贼草帽团悬赏金',// 主标题文本点击之后的超链接link: 'http://www.baidu.com',// 主标题文本样式textStyle:{color:'red',}},// x轴xAxis: {//类目轴type: 'category',data: ['路飞', '索隆', '娜美']},// y轴yAxis: {//数值轴type: 'value'},// 系列列表series: [{name: '悬赏金',//图标类型 bar柱状图type: 'bar',data: [92, 80, 72]}]}

以上代码运行效果图
在这里插入图片描述

三、Echarts的常用图表

3.1 通用配置

通用配置指的就是任何图表都能使用的配置

3.1.1、标题:title

Echarts中的title配置项手册

  • 文字样式
    textStyle
  • 标题边框
    borderWidth边框宽度、borderColor边框颜色、borderRadius标题圆角
  • 标题的位置
    left(左)、top(上)、right(右)、bottom(下)
3.1.2、提示:tooltip

Echarts中的tooltip配置项手册
tooltip:提示框组件,用于配置鼠标滑过或点击图表时的显示框

  • 触发的类型:trigger
    item(移入到轴内部触发)、axis(在轴上就会触发)
  • 触发的时机:triggerOn
    mouseover(鼠标滑过的时候展示),click(点击的时候触发)
  • 格式化:formatter
    支持字符串模板、回调函数
    formatter使用字符串模板、回调函数方法和注意事项
3.1.3、工具按钮:toolbox

Echarts中的toolbox配置项手册
toobox:ECharts提供的工具栏
内置有导出图片、数据视图、动态类型切换、数据区域的缩放、重置五个工具

  • 显示工具栏按钮feature
    • savaAsImage导出图片的功能
    • dataView数据视图的功能
    • restore重置的功能
    • dataZoom区域缩放的功能
    • magicType动态图表类型的切换
3.1.4、图例:legend

Echarts中的legend配置项手册
用于筛选系列,需要和series配合使用

  • legend中data是一个数组
  • legend中data的值需要和series数组中某组数据的name值一致

通用配置代码如下(示例):

<script>var mCharts = echarts.init(document.querySelector('#table1'))var option = {title: {text: '海贼草帽团悬赏金',link: 'http://www.baidu.com',// textStyle标题文本样式textStyle: {color: 'red',},// borderWidth标题边框宽度borderWidth: 1,// borderColor标题边框颜色borderColor: 'pink',// borderRadius标题边框圆角borderRadius:5,//   left(左)、top(上)、right(右)、bottom(下)控制标题位置left:30},//tooltip提示tooltip: {// trigger触发的类型trigger: 'axis',//  triggerOn触发的时机triggerOn: 'click',// formatter格式化// 方法一:字符串模板// formatter: '{b}的悬赏金是{c}亿'// 方法二:回调函数formatter:function(arg){console.log(arg)console.log(arg[0].name+'悬赏金是'+ arg[0].data)return arg[0].name+'悬赏金是'+ arg[0].data}},// toolbox工具按钮toolbox:{feature:{// savaAsImage导出图片的功能saveAsImage:{},// dataView数据视图的功能dataView:{},// restore重置的功能restore:{},// dataZoom区域缩放得功能dataZoom:{},// magicType动态图表类型的切换magicType:{type:['bar','line']}}},xAxis: {type: 'category',data: ['路飞', '索隆', '娜美']},yAxis: {type: 'value'},series: [{name: '悬赏金',type: 'bar',data: [92, 10., 10]}]}mCharts.setOption(option)</script>

以上代码运行效果图

  1. 标题:title
    在这里插入图片描述
  2. 提示:tooltip
    在这里插入图片描述
  3. 工具按钮:toolbox
    在这里插入图片描述
    在这里插入图片描述
    4.图例:legend
legend:{data:['悬赏金','战损']
},

legend完整代码如下(示例):

 <script>var mCharts = echarts.init(document.querySelector('#table1'))let yDataArr1 = [92, 10.1, 10]let yDataArr2 = [50, 25, 22]var option = {// title标题title: {text: '海贼草帽团悬赏金',link: 'http://www.baidu.com',// textStyle标题文本样式textStyle: {color: 'red',},// borderWidth标题边框宽度borderWidth: 1,// borderColor标题边框颜色borderColor: 'pink',// borderRadius标题边框圆角borderRadius: 5,//   left(左)、top(上)、right(右)、bottom(下)控制标题位置left: 30,},//tooltip提示tooltip: {// trigger触发的类型trigger: 'axis',//  triggerOn触发的时机triggerOn: 'click',// formatter格式化// 方法一:字符串模板// formatter: '{b}的悬赏金是{c}亿'// 方法二:回调函数formatter: function (arg) {console.log(arg)console.log(arg[0].name + '悬赏金是' + arg[0].data)return arg[0].name + '悬赏金是' + arg[0].data}},// toolbox工具按钮toolbox: {feature: {// savaAsImage导出图片的功能saveAsImage: {},// dataView数据视图的功能dataView: {},// restore重置的功能restore: {},// dataZoom区域缩放得功能dataZoom: {},// magicType动态图表类型的切换magicType: {type: ['bar', 'line']}}},//legend 图例legend:{data:['悬赏金','战损']},xAxis: {type: 'category',data: ['路飞', '索隆', '娜美']},yAxis: {type: 'value'},series: [{name: '悬赏金',type: 'bar',data: yDataArr1},{name: '战损',type: 'bar',data: yDataArr2}]}mCharts.setOption(option)</script>

在这里插入图片描述

3.2、Echarts中的7大图表

  • 图表1:柱状图
  • 图表2:折线图
  • 图表3:散点图
  • 图表4:饼图
  • 图表5:地图
  • 图表6:雷达图
  • 图表7:仪表盘图
3.2.1、图表1:柱状图

Echarts中的柱形图的常见效果配置项手册

  • 柱状图特点
    柱状图,描述的是分类数据,呈现的每一个分类中有多少,通过柱状图,可以很清晰看出每个分类数据的情况!

将数据通过柱状图来实现,以下是柱状图案例:
海贼悬赏金排行榜如下:

1.哥尔·D·罗杰 55亿6480万贝里
2.艾德华·纽盖特 50亿4600万贝里
3.海道 46亿1100万贝里
4.夏洛特·莉莉 43亿8800万贝里
5.红发杰克 40亿4890万贝里
6.蒙奇·D·路飞 30亿贝里(不排名先后顺序)
7.尤斯塔斯·基德 30亿贝里(不排名先后顺序)
8.托拉法尔加·罗 30亿贝里(不排名先后顺序)
9.马歇尔·D·汀奇 22亿4760万贝里
10.KING(亚尔贝鲁) 13亿9000万贝里

实现步骤

  1. Echarts最基本的代码结构:
    引入js文件。DOM容器,初始化对象,设置option

  2. X轴数据:
    数组1 : [‘哥尔·D·罗杰’,‘.艾德华·纽盖特’,‘海道’,‘.夏洛特·莉莉 ‘,‘红发杰克’,’.蒙奇·D·路飞’,‘尤斯塔斯·基德’,‘托拉法尔加·罗’,‘马歇尔·D·汀奇’,‘KING(亚尔贝鲁’]

  3. Y轴的数据:
    数组2:[55.648,50.46,46.11,43.88,40.489,30,30,30,22.476,13.9]

  4. 图表类型:
    在series下设置type:bar

代码如下(示例):

<!DOCTYPE html>
<html lang="en"><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>Document</title><script src="lib/echarts.js"></script>
</head><body><div id="table1" style="width: 1800px;height: 600px;"></div><script>let mCharts = echarts.init(document.querySelector('#table1'))//1.xDataAr是X轴数据let xDataArr =['哥尔·D·罗杰','艾德华·纽盖特','海道','.夏洛特·莉莉 ','红发杰克','蒙奇·D·路飞','尤斯塔斯·基德','托拉法尔加·罗','马歇尔·D·汀奇','KING(亚尔贝鲁']//2.yDataAr是Y轴数据let yDataArr = [55.648, 50.46, 46.11, 43.88, 40.489, 30, 30, 30, 22.476, 13.9]var option = {xAxis: {type:'category',data:xDataArr},yAxis:{type:'value',},series:[{name:'海贼悬赏金排行榜',// 3. 图表类型:在series的type值设置为bartype:'bar',data:yDataArr}]}mCharts.setOption(option)</script>
</body></html>

以上代码运行效果图
在这里插入图片描述

Echarts中的柱形图的常见效果

Echarts中的柱形图的常见效果配置项手册
1.标记: markPoint(配置最大值 、最小值) 、markLine(配置平均值)
2.显示: label设置show为true(数值显示) 、barWidth(柱宽度)、x轴和y轴配置互换一下(横向柱状图),rotate(旋转)
在series配置代码如下(实例)

series:[{name:'海贼悬赏金排行榜',type:'bar',data:yDataArr,label:{// show为true数值显示show:true,// rotate旋转rotate:60,// position数值显示位置// position:'top'},// barWidth柱宽度(没一列宽度)barWidth:'80%',//markPoint(配置最大值 、最小值)markPoint:{data:[{type:'max',name:'最大值'},{type:'min',name:'最小值'}]},//markLine(配置平均值 )markLine:{data:[{type:'average',name:'平均值'}]}
}]

以上代码运行效果图
在这里插入图片描述

3.2.2、图表2:折线图

实现步骤

  1. Echarts最基本的代码结构:

总结


持续更新中

如果这篇【文章】有帮助到你💖,希望可以给我点个赞👍,创作不易,如果有对前端端或者对python感兴趣的朋友,请多多关注💖💖💖,咱们一起探讨和努力!!!
👨‍🔧 个人主页 : 前端初见


http://www.ppmy.cn/news/894718.html

相关文章

知识图谱之《海贼王-ONEPICE》领域图谱项目实战(含码源):数据采集、知识存储、知识抽取、知识计算、知识应用、图谱可视化、问答系统(KBQA)等

项目设计集合&#xff08;人工智能方向&#xff09;&#xff1a;助力新人快速实战掌握技能、自主完成项目设计升级&#xff0c;提升自身的硬实力&#xff08;不仅限NLP、知识图谱、计算机视觉等领域&#xff09;&#xff1a;汇总有意义的项目设计集合&#xff0c;助力新人快速实…

数学教材推荐

数学书籍推荐 引言 一 数学分析 二 高等数学 三 高等代数 四 线性代数 五 解析几何 六 概率论 七 常微分方程 八 偏微分方程 九 数学物理方程(数学物理方法) 十 复变函数 十一 实变函数 十二 泛函分析 十三 高等几何 十四 微分几何 十五 拓扑学 十六 近世代数…

鲲志说:向我跌宕起伏,喜忧参半的2022致敬!

今天是2022的倒数第二天&#xff0c;就着CSDN的活动正好为自己做一个年度总结&#xff0c;也确实需要做一个年度总结来正式和过去的一年道个别 回想这一年&#xff0c;确实经历了很多&#xff0c;寒冬裁员、千里相赴见双方父母、成功夺冠&#x1f411;。。。成年人的世界确实很…

中心极限与大数定理律的关系_实数系基本定理(一)

确界 设 是 中的一个非空有上界数集. 若实数 满足&#xff1a; &#xff08;1&#xff09;对任何 &#xff0c;有 &#xff0c;即 是 的上界&#xff1b; &#xff08;2&#xff09;对于任意给定的 &#xff0c;存在 &#xff0c;使得 &#xff0c; 即 是 的最小上界. 则称…

机器学习和python学习之路精心整理技术书从入门到进阶

“机器学习&#xff0f;深度学习并不需要很多数学基础&#xff01;”也许你在不同的地方听过不少类似这样的说法。对于鼓励数学基础不好的同学入坑机器学习来说&#xff0c;这句话是挺不错的。不过&#xff0c;机器学习理论是与统计学、概率论、计算机科学、算法等方面交叉的领…

一位计算机牛人的心得,谈计算机和数学

转一位计算机牛人的心得&#xff0c;谈到计算机和数学&#xff0c;很实用~ 计算机科学与技术反思录 计算机科学与技术这一门科学深深的吸引着我们这些同学们&#xff0c;上计算机系已经有近三年了&#xff0c;自己也做了一些思考,我一直认为计算机科学与技术这门专业&#x…

数列极限:数列极限的概念

文章目录 数列极限的概念数列基础数列的概念特殊数列等差数列&#xff08;算术数列&#xff09;等比数列&#xff08;几何数列&#xff09;有界数列单调数列 子列 数列极限数列极限的定义数列极限的几何意义方式一方式二 数列的敛散性分析 参考文献 数列极限的概念 这一节&…

科研必备?年入百万?来看这份知乎大佬的图形学书籍清单!

学习一下知乎大佬的推荐书单 目前细分方向暂时分为Introduction&#xff08;介绍图形学、电影/动画工业的基础知识&#xff09;&#xff0c;Geometry Processing&#xff08;几何处理&#xff0c;建模等&#xff09;&#xff0c;Rendering&#xff08;离线/实时渲染&#xff0…