📢 C语言专栏:想学C语言的,冲
📢?VUE专栏:想学VUE的,冲这里
📢?CSS专栏:想学CSS的,冲这里
📢 Krpano专栏:想学VUE的,冲这里
🔔 上述专栏,都在不定期持续更新中!!!!!!!!!!!!!
目录
?
??
亲爱的小白用户,我来啦!
????????学绘画的第一步是学会用铅笔画一条直线,编程的第一步是输出一个 “Hello World”,使用 ECharts 的第一步,就是配置出一个最简单的柱状图。
????????什么,你还不会?别急,LETTRE 传授你独门秘笈,让你快速上手 ECharts,防止在群里被嘲讽成“啥也不会的小白”。
????????首先,你需要准备好 DOM 容器,HTML 部分我们就不多说了,直接上干货:
// 初始化 ECharts 实例
let myChart = echarts.init(document.getElementById('main'))
// 配置项
let option = {
xAxis: {
// ...省略坐标轴配置
},
yAxis: {
// ...省略坐标轴配置
},
series: [{
name: '销量',
type: 'bar',
data: [5, 20, 36, 10, 10]
}]
}
// 设置配置项
myChart.setOption(option)
????????看,就是这么简单,代码量还不到 10 行,一个基础柱状图就出来了!
????????如果你还觉得有难度,不要灰心,我来手把手教你配置每个属性,保证通关无忧虑。我们一起进入 ECharts 的海洋,感受数据可视化的魅力!
这两个配置项决定了图表的宽度和高度。默认情况下,ECharts 会自动获取所属 DOM 容器的宽高来设置图表尺寸。
示例:
let option = {
width: 500,
height: 400
}
renderer 决定使用何种方式渲染图表,可选 'canvas' 或 'svg'。
示例:
let option = {
renderer: 'svg'
}
这个配置项可以提高图表在高分屏下的显示效果。如果设置为 2,则表示提高像素密度,使得图形的显示更加清晰。
示例:
let option = {
devicePixelRatio: 2
}
title 用于设置图表的主标题,包含三个属性:
示例:
let option = {
title: {
text: '主标题',
subtext: '副标题',
left: 'left'
}
}
legend 用于设置图例,包含的属性有:
示例:
let option = {
legend: {
data: ['系列1', '系列2'],
orient: 'vertical',
left: 'left'
}
}
注意:
legend图例需要配合?Series 去使用
grid 用于设置图表的网格系统,可以通过它来调整图表区域的位置。常见属性有:
示例:
let option = {
grid: {
left: '10%',
top: 60,
width: '80%',
height: '60%'
}
}
xAxis 和 yAxis 分别用于设置横轴和纵轴的相关配置,常见属性包括:
示例:
let option = {
xAxis: {
type: 'category',
name: 'x 轴',
nameLocation: 'middle',
nameGap: 30
},
yAxis: {
type: 'value',
name: 'y 轴'
}
}
series 数组用于配置每个系列(数据系列)的类型、名称、数据等。通常一个图表由多个系列组成。常见属性有:
示例:
let option = {
series: [
{
name: '系列1',
type: 'line',
data: [5, 20, 36, 10, 10]
},
{
name: '系列2',
type: 'bar',
data: [55, 20, 16, 20, 10]
}
]
}
tooltip 用于配置提示框组件,常用属性:
示例:
let option = {
tooltip: {
trigger: 'item',
formatter: '{b}: {c}',
backgroundColor: 'rgba(0,0,0,0.7)'
}
}
visualMap 用于进行『视觉编码』,也就是将数据映射到视觉元素(如颜色)。常用属性:
示例:
let option = {
visualMap: {
min: 0,
max: 100,
inRange: {
color: ['#313695', '#4575b4']
},
outOfRange: {
color: '#ccc'
}
}
}
dataZoom 用于设置数据区域缩放组件,实现图表数据的区域缩放。常用属性:
示例:
let option = {
dataZoom: {
type: 'slider',
start: 10,
end: 60
}
}
magicType 的配置可以切换图表类型,常用值包括:
示例:
let option = {
// 让图表支持 line、bar 切换
magicType: {
type: ['line', 'bar']
}
}
restore 配置可以提供还原和重置按钮,方便用户重置为默认状态。
示例:
let option = {
// 开启还原和重置功能
restore: {}
}
encode 可以声明数据到视觉的映射,更加灵活地配置各个数据与图形属性的关系。
series: [{
encode: {
x: '时间',
y: '指数',
tooltip: ['时间', '指数']
}
}]
用于对特定数据进行标记,常用于呈现最大值、最小值等特殊点。
series: [{
markPoint: {
data: [
{name: '最大', value: 180},
{name: '最小', value: 2}
]
}
}]
用于标线,可以标注平均线、警戒线等。
series: [{
markLine: {
data: [{
name: '平均线',
yAxis: 10
}]
}
}]
扩展轴标签的各种设置,如:
xAxis: {
axisLabel: {
interval: 0, // 强制显示所有标签
rotate: 30, // 旋转角度
margin: 20, // 刻度标签与轴线之间的距离
}
}
扩展轴刻度的各种设置,如:
yAxis: {
axisTick: {
show: false, // 不显示刻度线
}
}
扩展轴网格线的各种设置,如:
xAxis: {
splitLine: {
lineStyle: {
color: '#ddd',
width: 1
}
}
}
graphic 组件用于自定义更丰富的图形,支持矩形、圆、路径、图片等。
graphic: {
elements: [{
type: 'rect',
left: 20,
top: 20,
width: 100,
height: 50,
style: {
fill: 'red'
}
}]
}
timeline 组件实现时间线Controls,可以播放并对比不同时间的图表。
timeline: {
axisType: 'category',
autoPlay: true,
playInterval: 1000
}
持续更新文档内容...
????????这样,我们就基本介绍完了 ECharts 的常用配置项,后续还会在此文章中持续更新更多配置。从基础的大小设置和标题组件,到复杂的坐标轴控制和数据视觉映射,ECharts 为数据可视化提供了强大而丰富的配置能力。
????????在继续深入学习 ECharts 时,不要被琳琅满目的配置项吓到。好的绘图作品需要细致的配置结合创意,但初学者完全可以从简单的配置入手,逐步掌握。将数据变成直观的可视化表达,既考验技巧,也是一种乐趣。
????????ECharts 还在持续更新,未来必将支持更多炫酷的配置和交互。在它的世界里,我们可以给数据赋予生命,将枯燥的数字变成生动的画卷。让我们在数据可视化的process中持续学习和创造,产出更多有价值的图表作品吧!
????????我们改日再会