Echarts创建

一个网页中可以创建多个echarts图例。一个DOM节点可作为echarts的渲染容器。每个DOM节点只能放一个echarts实例。

series 系列

一个系列至少包含的要素为:一组数值,图表类型(series.type),以及其他的关于这些数据如何映射成图的参数。

图表类型

echarts中的图表类型主要为:line-折线,bar-柱状图,pie-饼图,scatter-散点图,graph-关系图,tree-树图,等等

类同地,系列的数据从dataset中获取的另一种配置方式。

component 组件

在系列之上,echarts中各种内容,被抽象的称为组件。

组件类型
series-系列,
legend-图例组件
tooltip-提示框组件,
toolbox-工具栏组件,
xAxis-直角坐标系x轴,
yAxis-直角坐标系y轴,
grid-直角坐标系底板,
angleAxis-极坐标轴角度轴,
radiusAxis-极坐标系半径轴,
polar-极坐标系底板,
geo-地理坐标系,
dataZoom-数据区缩放组件
visualMap-视觉映射组件,

option 描述图表

使用 option 来描述其对图表的各种需求,包括:有什么数据、要画什么图表、图表长什么样子、含有什么组件、组件能操作什么事情等等。简而言之,option 表述了:数据、数据如何映射成图形、交互行为。

// 创建 echarts 实例。
var dom = document.getElementById('dom-id');
var chart = echarts.init(dom);// 用 option 描述 `数据`、`数据如何映射成图形`、`交互行为` 等。
// option 是个大的 JavaScript 对象。
var option = {// option 每个属性是一类组件。legend: {...},grid: {...},tooltip: {...},toolbox: {...},dataZoom: {...},visualMap: {...},// 如果有多个同类组件,那么就是个数组。例如这里有三个 X 轴。xAxis: [// 数组每项表示一个组件实例,用 type 描述“子类型”。{type: 'category', ...},{type: 'category', ...},{type: 'value', ...}],yAxis: [{...}, {...}],// 这里有多个系列,也是构成一个数组。series: [// 每个系列,也有 type 描述“子类型”,即“图表类型”。{type: 'line', data: [['AA', 332], ['CC', 124], ['FF', 412], ... ]},{type: 'line', data: [2231, 1234, 552, ... ]},{type: 'line', data: [[4, 51], [8, 12], ... ]}}]
};// 调用 setOption 将 option 输入 echarts,然后 echarts 渲染图表。
chart.setOption(option);

系列里的 series.data 是本系列的数据。而另一种描述方式,系列数据从 dataset 中取:

var option = {dataset: {source: [[121, 'XX', 442, 43.11],[663, 'ZZ', 311, 91.14],[913, 'ZZ', 312, 92.12],...]},xAxis: {},yAxis: {},series: [// 数据从 dataset 中取,encode 中的数值是 dataset.source 的维度 index (即第几列){type: 'bar', encode: {x: 1, y: 0}},{type: 'bar', encode: {x: 1, y: 2}},{type: 'scatter', encode: {x: 1, y: 3}},...]
};

组件的定位

【类css的绝对定位】

多数组件和系列,都能够基于top、right、down、left、width、height绝对定位,这种类似于css的绝对定位(position:absolute)。绝对定位是基于echarts容器的DOM节点。
其中,他们每一个值都可以是:
① 绝对数值:如bottom:54 ,距离echarts容器底边界54px
② 基于echarts容器高宽的百分比:如right:‘20%’

left right width 是一组(横向)、top bottom height 是另一组(纵向)。这两组没有什么关联。每组中,至多设置两项就可以了,第三项会被自动算出。

【中心半径定位】

少数圆形的组件或系列,可以使用“中心半径定位”,例如,pie(饼图)、sunburst(旭日图)、polar(极坐标系)。

中心半径定位,往往依据 center(中心)、radius(半径)来决定位置。

坐标系

直角坐标系、极坐标系、地理坐标系(GEO)、单轴坐标系、日历坐标系等。其他一些系列,
pie(饼图)、tree(树图)等等,并不依赖坐标系,能独立存在。还有一些图,例如 graph(关系图)等,既能独立存在,也能布局在坐标系中。

再来看下图,两个 yAxis,共享了一个 xAxis。两个 series,也共享了这个 xAxis,但是分别使用不同的 yAxis,使用 yAxisIndex 来指定它自己使用的是哪个 yAxis:

再来看下图,一个 echarts 实例中,有多个 grid,每个 grid 分别有 xAxis、yAxis,他们使用 xAxisIndex、yAxisIndex、gridIndex 来指定引用关系:

一个系列,往往能运行在不同的坐标系中。例如,一个 scatter(散点图)能运行在 直角坐标系、极坐标系 、地理坐标系(GEO) 等各种坐标系中。同样,一个坐标系,也能承载不同的系列,如上面出现的各种例子,直角坐标系 里承载了 line(折线图)、bar(柱状图)等等。

感谢

以上内容均来自echarts官网文档
Echarts基础概念概览

Echarts中series、option、component究竟是啥?相关推荐

  1. echarts中series下的data循环拼接

    页面效果 x轴为每年存在数据的月份,因而不一定是12个月,每个月又包含对应的天数 y轴为充电量 获取数据 listCarChargingKWHChart() {var _this = this;lis ...

  2. JS 中的 assign 方法究竟是 “深克隆” 还是 “浅克隆”?

    先说一下答案:assign做的是浅克隆. "第一层是深克隆,下面的每一层做的是浅克隆" 这种说法其实是错误的.    在我们去探究assign是深克隆还是浅克隆之前,我们必须先明白 ...

  3. ECharts中setOption的title、tooltip、xAxis、yAxis、series、legend等参数的含义。

    ECharts中setOption的title.tooltip.xAxis.yAxis.series.legend等参数的含义. title //标题设置 legend //图例控制 grid //图 ...

  4. ECharts 中的事件和行为

    更多关于Apache ECharts的文档,请阅读: Apache ECharts文档专题 <Apache ECharts教程> 5 分钟上手 ECharts ECharts 5 新特性 ...

  5. Echarts中treemap实现知识地图的逐层展开

    1.演示效果 2.代码呈现 import React, { Component } from 'react'; import './App.css'; //需要先运行npm install echat ...

  6. 在echarts中自定义提示框内容

    1.期望效果 以柱状图为例,在鼠标滑过每个数据标签时,为了更友好地显示数据内容,需要对显示的数据内容作格式化处理,添加自定义内容. 如下图,鼠标滑过每个数据项时, 第1张是默认提示框: 第2张是处理成 ...

  7. echarts饼图解析html标签,解决echarts中饼图标签重叠的问题

    饼图中的series有个avoidLabelOverlap属性, avoidLabelOverlap:是否启用防止标签重叠策略,默认开启,在标签拥挤重叠的情况下会挪动各个标签的位置,防止标签间的重叠. ...

  8. echarts中如何使用timeline组件

    1.吃碗面 这里关于echarts3 官网的示例我不得不吐槽一下,逼格真高!一小部分示例动不动数据就是国家统计局搞出来的,你脸真大.当然他们做的示例的确是很好,这一点毫无疑问.当我看了echarts3 ...

  9. html文件在echarts中,老师,echarts中所有的案例都是.html属性的文件吗?

    置顶 老师参与 老师,echarts中所有的案例都是.html属性的文件吗? 我是管理员大大 发表于2019年11月26日 如下是echarts中的实例,想请教一下,这是什么属性的文件? app.ti ...

最新文章

  1. JavaSE--jdom解析之bom
  2. 2018年全球AI突破性技术TOP10
  3. MFC中OnTimer函数的使用方法
  4. 开源数据分析工具 CyberChef
  5. OSSemPend()--等待一个信号量
  6. linux 链表头文件,Linux下单链表的实现
  7. 微软双机双柜方案讨论
  8. Android NDK开发之 opencv manage 免安装生成opencv应用
  9. 2021FME博客大赛 —— FME在道路实景建模中的应用研究
  10. K8S知道,K9S又是个什么鬼?
  11. android sd卡 spi,SD卡总结-SPI模式
  12. 开放平台-web实现人人网第三方登录
  13. ubuntu16.04 360随身WiFi2
  14. micropython esp32驱动舵机_关于micropython ESP32的MQTT通讯方式控制舵机
  15. Android 原生 多屏显示 (分屏) 原理 解析
  16. appJSON[tabBar][borderStyle] 字段需为 black 或 white console.error @ VM1402:1 (anonymous) @ VM1415:2
  17. 公钥基础设施 (Public-key infrastructure PKI)
  18. 【众说区块链】公链是否一定要发币,Token到底应该怎么理解?
  19. FreeRTOS 任务简介
  20. Hbase JavaAPi介绍和使用示例(待更新)

热门文章

  1. R语言连续变量等级划分
  2. Python双引号与单引号的使用
  3. 中科大凌青老师凸优化课程——目录
  4. 如何用关键字查找PDF中的文字内容?
  5. gorm升级V1至V2
  6. 游戏陪玩APP开发的功能和特点
  7. 华为官方出品:首本HMS Core技术解析图书问世
  8. 【Vue.js】实现随机抽奖
  9. 【多校训练】2021牛客多校5
  10. Java房地产销售管理系统_JAVA JSP房地产销售系统 源代码 论文