echarts-dataset数据源配置项

news/2024/4/27 0:30:30/文章来源:https://www.cnblogs.com/origin-zy/p/16635934.html

 如下效果图:

 

 

 代码入下:

  let box4 = document.querySelector('.box4')let myCharts3 = echarts.init(box4)myCharts3.setOption({dataset:{// 二维数组存放数据
                source:[//     0    1  2  3  4  5    六个维度['衣服',22,15,36,35,18],['食品',60,39,50,15,22],['生活用品',60,52,36,15,36],['家具',45,32,8,25,46],['厨具',35,42,26,5,16],['裤子',10,22,46,42,56]]},title: {text: "dataset数据集",subtext: '折线、柱状、饼图',left: "center"},xAxis: {data: ['衣服', '食品', '生活用品', '家具', '厨具', '裤子']},yAxis: {// 设置是否显示y轴线
                axisLine: {show: true},// 设置是否显示y轴刻度
                axisTick: {show: true}},series: [{type:"line",// 选择使用哪一个维度
                    encode:{// 使用1维度映射到y轴上y:2}},{type:"bar",encode:{// 使用1维度映射到y轴上y:4}},{type:"pie",width:"260px",height:"260px",top:"-60px",left:"500px",radius:["0%","40%"],encode:{// 饼图旁边的文字// 使用0维度映射itemName:0,// 使用4维度映射value:4}}]})

  实例中 dataset 用 source 配置项接收一个二维数组,series 用 encode 来与x,y轴映射数据

下面介绍几中 dataset 的组织形式,还有 series 的映射的方式

  1.   按行的key --value 形式
dataset: {source: [{ value: 1048, name: 'Search Engine' },{ value: 735, name: 'Direct' },{ value: 580, name: 'Email' },]
},
series: [{type: 'pie',encode: {itemName: 'name',value: 'value'}}
]

 

  1.        按列的key --value 形式
dataset: {source: {name: ['Search Engine', 'Direct', 'Email'],value:[1048, 735, 580],}
},
series: [{type: 'pie',encode: {itemName: 'name',value: 'value'}}
]

 

  1.        二维数组(如实例)
//按列取数的形式
dataset: {source: [['name', 'value'],['Search Engine', 1048],['Direct', 735,],['Email',580]],
},
series: [{type: 'pie',encode: {itemName: 'name',value: 'value'}}
]//按行取数的形式
dataset: {source: [['name','Search Engine','Direct','Email'],['value',1048,735,580]],
},
series: [{type: 'pie',seriesLayoutBy: 'row',//默认为column,即默认是取第一行作为维度名信息,需要改成列
      encode: {itemName: 'name',value: 'value'}}
]

 

  1.        利用dimensions
//按列取数的形式
dataset: {source: [['Search Engine', 1048],['Direct', 735,],['Email',580]],dimensions: ['name', 'value'],
},
series: [{type: 'pie',encode: {itemName: 'name',value: 'value'}}
]

处理Axios清求到的数据时就得将其组织成以上三种形式中获得任意一种

处理方法如下

  指标的数据的组织形式就是数据立方体的新式后端的DTO如下

/*** 统计通用dto*/
@Data
@ApiModel(description = "统计通用dto")
public class StatisticsDTO {@ApiModelProperty(value = "统计数据")List<Map<String, Object>> statistics;@ApiModelProperty(value = "维度取值")Map<String, List<String>> dimensionValues;@ApiModelProperty(value = "维度分层统计")Map<String, List<Map<String, Object>>> hierarchyDimensionData;
}

Responses 数据如下格式

  
{"code": 0,"data": {"dimensionValues": {"additionalProp1": ["string"],"additionalProp2": ["string"],"additionalProp3": ["string"]},"hierarchyDimensionData": {"additionalProp1": [{"additionalProp1": {},"additionalProp2": {},"additionalProp3": {}}],"additionalProp2": [{"additionalProp1": {},"additionalProp2": {},"additionalProp3": {}}],"additionalProp3": [{"additionalProp1": {},"additionalProp2": {},"additionalProp3": {}}]},"statistics": [{"additionalProp1": {},"additionalProp2": {},"additionalProp3": {}}]},"msg": "string"
}

拿到的数据需要过滤,或者排序

//   *就是所有,不加限制条件
//    所有维度都等于* ,则就是就全部的指标和或计数或最值const filtersource = data.data.statistics.filter((obj) =>obj.CaseType != '*' &&obj.Datasource != '*' &&obj.MaterialType != '*' &&obj.MaterialGrade != '*');
//排序data.statistics.sort((item1, item2) => {if (item1.Field > item2.Field) {return 1;} else if (item1.Field < item2.Field) {return -1;}return 0;});

将过滤的数据组织成上述的三种形式

//二维数组形式 const sourceLists: Recordable[] = [];
//二维数组第一项   根据某一维度放x轴
//往后项     根据第二维度放legend图例//[维度x, 图例, 图例,];//[维度x, 图例, 图例, ;for (let entity of data.dimensionValues.AssessmentDate) {var sourceList: Recordable[] = [0, 0, 0, 0, 0, 0];sourceList.splice(0, 1, entity);for (let obj of filtersource) {if (obj.AssessmentDate == entity) {switch (obj.Field) {case '海一采油管理区':sourceList.splice(1, 1, obj.count);break;case '海二采油管理区':sourceList.splice(2, 1, obj.count);break;case '海三采油管理区':sourceList.splice(3, 1, obj.count);break;case '海四采油管理区':sourceList.splice(4, 1, obj.count);break;case '集输大队':sourceList.splice(5, 1, obj.count);break;default:console.log('Unknown filter');break;}}}sourceLists.push(sourceList);

到此在series映射绑定(name映射到对应的图例)

 series: [{name: '海一采油管理区',type: 'line',smooth: true,barWidth: '10%',itemStyle: {color: '#5ab1ef',},areaStyle: {normal: {areaStyle: {normal: {color: (0, 0, 0, 1),},},},},},{name: '海二采油管理区',type: 'line',smooth: true,barWidth: '10%',itemStyle: {normal: {barBorderRadius: 2,color: '#4daaf8',},},},{name: '海三采油管理区',type: 'line',smooth: true,barWidth: '10%',itemStyle: {normal: {barBorderRadius: 2,color: '#2cde87',},},areaStyle: {normal: {areaStyle: {normal: {color: (0, 0, 0, 1),},},},},},{name: '海四采油管理区',type: 'line',smooth: true,barWidth: '10%',itemStyle: {normal: {barBorderRadius: 2,color: '#ffa43a',},},areaStyle: {normal: {color: (0, 0, 0, 1),},},},{name: '集输大队',type: 'line',smooth: true,barWidth: '10%',itemStyle: {normal: {barBorderRadius: 2,color: '#ffce3a',},},areaStyle: {normal: {color: (0, 0, 0, 1),},},},],

注意要将数据请求放到页面加载时运行的钩子函数中

      //页面加载时运行onMounted(async () => {await loadData();// emit('register', { reloadData });});

 

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

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

相关文章

RN 调试

使用前先关闭debugger模式关闭谷歌,在打开调试工具,然后再打开debugger 1.使用谷歌浏览器来调试不能查看标签结构不能查看网络请求 2.使用rn推荐的工具react-native-debugger来调试https://github.com/jhen0409/react-native-debugger/releases可以查看标签结构不能查看网络请…

Excel聚光灯设置

1.同时按住 ALT+F11进入vba 2.双击要设置的sheet页 3.输入以下代码Private Sub Worksheet_SelectionChange(ByVal Target As Range)Cells.Interior.ColorIndex = xlNoneTarget.EntireRow.Interior.ColorIndex = 24Target.EntireColumn.Interior.ColorIndex = 24End Sub4.效果如…

【三维地图】开发攻略 —— 详解“GeoJSON”技术和应用场景

GeoJSON ,一个用于存储地理信息的数据格式。GoeJSON对象可以表示几何、特征或特征集合,支持:点、线、面、多点、多线、多面和几何集合。在基于平面地图,三维地图中都需要用到的一种数据类型。 由于这种格式在三维地图中的优秀属性,使用它我们不仅可以轻松实现地图类功能,…

JavaScript设计模式及代码实现——单例模式

单例模式1 定义保证一个类仅有一个实例,并提供一个访问它的全局访问点。2 应用时机当一个类的实例被频繁使用,如果重复创建这个实例,会无端消耗资源。比如 dialog 弹窗会被全局重复使用 业务功能本身决定了全局只能有唯一的实例。比如 redux 管理的数据,只能有唯一的一份3 …

ubuntu18.04屏幕录制Vokoscreen

Vokoscreen 可被视为具有良好分类菜单的简单屏幕录制机的更好 UI 版本。- 除了在simplescreenrecorder中包含的所有功能,Vokoscreen 还支持外部网络摄像头以及内置网络摄像头。 然而,它不支持在simplescreenrecorder中可用的 JACK 音频。 下载命令:sudo apt install vokoscr…

磁共振成像原理

目录1. 原子核的自旋2. 进动3. 磁共振现象4. 射频脉冲1. 原子核的自旋 原子有原子核和绕核运动的电子组成。 原子核的自旋:质子数和中子数一个为奇数、一个为偶数; 两者都为奇数这两种情况的原子核就会自旋。原子核是带正电,绕自旋轴旋转,效应相当于环形电流,周围会产生磁…

业务流程可视化-让你的流程图Run起来(7.运行状态持久化轻量工作流支持)

前言 感谢大家阅读本项目系列文章和对项目的支持。分享一下我对这个项目的新的改进。 之前项目做到了流程设计可视化和流程运行结果可视化。 本期发布的版本中实现了中间的运行过程的实时可视化,和流程状态持久化问题。 大家可以根据项目提供的接口自由扩展自己的工作流实现。…

DataGrip连接Mysql报08S01解决方案

以前正常使用的GataGrip,突然在某天报下面的错误提示:08S01 [08S01]Communications link failureThe last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. No appropriate protocol (protocol is…

数据结构面试总结【第一弹】

数据结构面试总结 目录数据结构面试总结1.数据结构基本概念1.1 数据结构三要素2.线性表2.1 数组与链表有什么关系2.2 线性表的存储结构2.3 头指针和头节点的区别2.4 栈和队列的区别3.树3.1 度数为2的树与二叉树有什么区别3.2 唯一确定一棵二叉树3.3 二叉排序树3.4 最小生成树有…

优爱酷模拟点击自动翻页_自动展开所有批量网页转mhtml单网页保存

优爱酷模拟点击自动翻页_自动展开所有批量网页转mhtml#涨知识# 终于可以解放双手了! 1、页面有很多“折叠”的需要“展开”的内容,例如:点击查看全文,展开 等的网页,1个还好,多个“展开”如何解决?如果能#自动展开#岂不美哉? 2、普通网页翻页后链接会变化成不一样的,遇…

Ps 2022在M1 mac上导出 PNG 格式发生未知错误如何解决?

Photoshop 2022 for mac 在M1上导出 PNG 时,会提示“发生了未知错误”,即使点击“导出”按钮,导出的图片也是一个空白文件。小编教给大家 Ps 2021在 M1 mac上导出 PNG 格式发生未知错误的解决方法。1.打开 PhotoShop 的首选项 >常规,如下图所示:(也可以通过快捷键 Com…

图数据库入门教程(二)认识tinkerpop与gremlin

上一篇文章我们对图数据库有了一个简单的理解,对于关系的计算优雅而快速,适用与一些关系计算的场景,比如社交网络、金融反欺诈、商机发现、智能推荐等,想了解更多可以看一下阿里云gdb的文档https://help.aliyun.com/document_detail/112465.html。 当前图数据库天下的形式 …

设计模式之(3)——抽象工厂方法模式

定义:抽象工厂模式简单地讲,就是提供一个超级工厂,围绕这个超级工厂创建其他工厂;抽象工厂模式提供一个创建一些列相关或者相互依赖对象的接口;在此之前我们先来讲一下产品等级和产品族的概念;相同的产品等级就是相同的同一类的产品,比如美的冰箱、格力冰箱、海尔冰箱,…

Mysql----事务

《需求》 《操作》 《细节》

分类数据展示功能_缓存优化_分析

分类数据展示功能_缓存优化_分析 对数据进行一个缓存优化,分析发现:分类的数据在每一次页面加载后会重新请求数据库来加载,对数据库的压力比较大,而且这数据不会经常发送变化,可使用redis来缓存这个数据 分类数据展示功能_缓存优化_代码实现public class CategoryServiceI…

日常问题: 上线确认

作为开发,手头没事的时候,担心自己没参与大项目,年终没产出。而真正需求到来的时候,却是狂风暴雨一般,密集且时间紧迫。在紧锣密鼓996之后,终于迎来了上线。 但这一天不太顺利。背景 xxx正式上线。上线前,方案强调要开发把所有配置都给到他,他要确认下。当时觉得有问题…

第一个代码Hello World!

HelloWorld新建一个文件夹,存放代码新建一个Java文件 文件后缀为.java名为Hello.java[注意]要显示系统后缀名编写代码 public class Hello{ public static void main(String[] arge){ System.out.print("Hello,World!"); }} 打开cmd 路径需要是Hello.j…

Linux

1、关机命令命令 说明sync 将数据由内存同步到硬盘中shutdown 关机shutdown -h 10 10分钟后关机shutdown -h now 立马关机shutdown -h 20:25 指定时间关机shutdown -h +10 10分钟后关机shutdown -r now 系统立马重启shutdown -r +10 10分钟后重启reboot 重启,等于shutdown -r …

线性布局LinearLayout

线性布局中的下级视图有两种排列方式当orientation属性为horizontal时,线性布局中的下级视图在水平方向上从左往右排列 当orientation属性为vetical时,线性布局中的下级视图在垂直方向上从上往下排列线性布局的权重 概念:线性布局的权重,用来表示线性布局中各视图所占比例大…

NC50439 tokitsukaze and Soldier

在一个游戏中,tokitsukaze需要在n个士兵中选出一些士兵组成一个团去打副本。 第i个士兵的战力为v[i],团的战力是团内所有士兵的战力之和。 但是这些士兵有特殊的要求:如果选了第i个士兵,这个士兵希望团的人数不超过s[i]。(如果不选第i个士兵,就没有这个限制。) tokitsukaz…