使用Echarts中遇到值得记录的小案例(一)
需求部分
在开发项目的时候遇到一个需求,就是如何保证echarts图表里至少显示一个图例的数据(也就是最后一个图例不能变成unselected的状态)
下图是最初加载时的画面
不想出现图例都被点击取消导致图表只有一个坐标轴,太丑了
参考依据
在发帖前查阅了一些思路:
- 有用单选模式曲线救国的,但是就没有办法看到多条图例的数据在同一个图表里显示
- 有图例为最后一个的时候,禁用所有图例的点击事件
都不是能够很好的解决,找到一个可以参考的代码
var option = {
title: {
text: '折线图堆叠'
},
tooltip: {
trigger: 'axis'
},
legend: {
data:['邮件营销','联盟广告','视频广告','直接访问','搜索引擎']
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
toolbox: {
feature: {
saveAsImage: {}
}
},
xAxis: {
type: 'category',
boundaryGap: false,
data: ['周一','周二','周三','周四','周五','周六','周日']
},
yAxis: {
type: 'value'
},
series: [
{
name:'邮件营销',
type:'line',
stack: '总量',
data:[120, 132, 101, 134, 90, 230, 210]
},
{
name:'联盟广告',
type:'line',
stack: '总量',
data:[220, 182, 191, 234, 290, 330, 310]
},
{
name:'视频广告',
type:'line',
stack: '总量',
data:[150, 232, 201, 154, 190, 330, 410]
},
{
name:'直接访问',
type:'line',
stack: '总量',
data:[320, 332, 301, 334, 390, 330, 320]
},
{
name:'搜索引擎',
type:'line',
stack: '总量',
data:[820, 932, 901, 934, 1290, 1330, 1320]
}
]
};
myChart.setOption(option);
myChart.on('legendselectchanged', function (params) {
let option = this.getOption();
let select_key = Object.keys(params.selected);
if (!params.selected[params.name]) {
select_key.map(res => {
option.legend[0].selected[res] = !params.selected[res];//只点击了一个图例,所以select_key里只有被选中的为false,
//对应的option.legend[0].selected[res]值就为true,
//即为高亮状态,其他的都取消显示,通俗的讲就成了单选模式
});
} else {
select_key.map(res => {
option.legend[0].selected[res] = false;//先让所有图例下的数据显示状态为false
});
option.legend[0].selected[params.name] = true;//再让你选中的那个图例的显示状态变为true
}
this.setOption(option)
});
分析依据
关键代码就是myChart.on('legendselectchanged', function (params){...}部分,这里涉及到了echarts里如何获取legend的点击事件,但是查看文档后没有示例不会写怎么办?没关系,用上面的示例代码,我们把代码里不明白的变量都打印出来分析一下例如console.log('params',params)和console.log('option',option),打印出来后,对照着官方文档一看就清晰明了很多,这段截图后面我会补上。
下面说一下上面的这段代码的意思,select_key是legend图例选中状态的对应key-value对json,高亮的为false,取消的是true(这里和咱们理解的高亮为true是相反的),进入if语句后用map将select_key中的每一个元素遍历使得option.legend[0].selected[res]值为select_key里boolean值的相反值。
说到这里可能会有点绕,option.legend[0]里的selected也是一个key-value对json,高亮为true,取消为false,和select_key里的表现效果恰恰相反。
所以,这段代码的实现效果就是,当图例均为高亮时select_key = {'a':false,'b':false,'c':false,'d':false},点击b图例,此时select_key['b']=true,于是进入了else代码块,如上面代码注释所写,图例由多变一,此时select_key = {'a':true,'b':false,'c':true,'d':true},这时候有两种操作:
- 再次点击b图例后select_key = {'a':true,'b':true,'c':true,'d':true},图例状态均为不显示的状态,此时代码进入if代码块,所有的图例状态变成相反值,于是四个图例全部被选中,图表显示四条折线
- 点击其他图例,比如c,同理进入else代码块后,所有状态为不显示,再给选中的c图例重新赋值使其显示
解决方案
OK,到这里我们就明白了上面那段代码到底是什么意思了,所以究竟该如何实现我们需要的功能呢,有意思的是Object.values(params.selected)会返回一个图例选中态的布尔值数组,相当于重组了我们之前声明的select_key里各项的value值,我们只需在这个布尔值数组里只有一个false的时候,手动将其显示状态重新赋值为true即可(option.legend[0].selected[params.name] = true;)
话不多说上代码
myChart.on('legendselectchanged', function (params) {
let option = this.getOption();
let select_key = Object.keys(params.selected);
let select_value = Object.values(params.selected);
console.log('select_value',select_value,'length',select_value.length)
var n = 0;
select_value.map(res => {
if(!res){
n++;
}
});
console.log('n',n)
if( n ==select_value.length){ //如果最后一个图例点击后select_key里的选中态会变为false,
//既有四个false,当有4个false的时候将最后选中的图例的实际显示值改为true
option.legend[0].selected[params.name] = true;
}
this.setOption(option)
});
第一次写博文总结,可能有点表述不清,还请见谅,欢迎讨论
使用Echarts中遇到值得记录的小案例(一)的更多相关文章
- java记录在线人数小案例
文件目录: web.xml: <?xml version="1.0" encoding="UTF-8"?> <web-app version= ...
- Java提取文本文档中的所有网址(小案例介绍正则基础知识)
正则表达式基础以及Java中使用正则查找 定义: 正则表达式是一些用来匹配和处理文本的字符串 正则的基础(先大致了解下) 1. 正则表达式的作用 查找特定的信息(搜索) 替换一些文本(替换) 2. 正 ...
- C++中几个值得分析的小问题(1)
下面3个小问题都是我认为C++ Beginner应该能够解答或辨别清楚的.希望我们能通过题目挖掘更多的信息,而不仅仅局限在解题.我最喜欢说的话:能力有限,所以作为抛砖引玉,希望共同讨论,指出错误. 另 ...
- C++中几个值得分析的小问题(2)
下面有3个小问题,作为C++ Beginner你一定要知道错在哪里了. 1.派生类到基类的引用或指针转换一定“完美”存在? 一般情况,你很可能会认为:派生类对象的引用或指针转换为基类对象的引用或指针是 ...
- WebSphere中数据源连接池太小导致的连接超时错误记录
WebSphere中数据源连接池太小导致的连接超时错误记录. 应用连接超时错误信息: [// ::: CST] webapp E com.ibm.ws.webcontainer.webapp.WebA ...
- 转:浅谈CSS在前端优化中一些值得注意的关键点
前端优化工作中要考虑的元素多种多样,而合理地使用CSS脚本可以在很大程度上优化页面的加载性能,以下我们就来浅谈CSS在前端优化中一些值得注意的关键点: 当谈到Web的“高性能”时,很多人想到的是页面加 ...
- SQL Server-删除表中重复的记录!
比如现在有一人员表 (表名:peosons)若想将姓名.身份证号.住址这三个字段完全相同的记录查询出来 select p1.* from persons p1,persons p ...
- SQL开发中容易忽视的一些小地方(一)
原文:SQL开发中容易忽视的一些小地方(一) 写此系列文章缘由: 做开发三年来(B/S),发现基于web 架构的项目技术主要分两大方面: 第一:C#,它是程序的基础,也可是其它开发语言,没有开发语言也 ...
- SQL开发中容易忽视的一些小地方(二)
原文:SQL开发中容易忽视的一些小地方(二) 目的:继上一篇:SQL开发中容易忽视的一些小地方(一) 总结SQL中的null用法后,本文我将说说表联接查询. 为了说明问题,我创建了两个表,分别是学生信 ...
随机推荐
- javascript 调试 使用console.table()
或许你已经习惯了console.log()来调试js,非常使用,但是今天微博看到console.table()调试javascript,和console.log()类似,主要区别在于: 主要用来输出对 ...
- Vue动态添加响应式属性
不能给Vue实例.Vue实例的根数据对象添加属性. 文件 <template> <div id="app"> <h2>{{hello}}:{{a ...
- cts测试流程
测试目的: 用于检测你做的Android系统是否满足兼容性要求,通俗点说,Google认为Android系统应该满足的条件,你需要满足. 例如框架层暴露给应用层的某些接口,Google认为你因该有,那 ...
- 机器学习实战笔记-5-Logistic回归
Logistic回归 优缺点 适用范围 优点:计算代价不高,易于理解和实现. 缺点:容易欠拟合,分类精度可能不高. 适用于:数值型和标称型数据. 仅用于二分类 原理: 每个特征都乘以一个回归系数> ...
- 【python】 判断纯ascii串
参考:http://stackoverflow.com/questions/3636928/test-if-a-python-string-is-printable print all(ord(c)& ...
- Netty基础-BIO/NIO/AIO
同步阻塞IO(BIO): 我们熟知的Socket编程就是BIO,每个请求对应一个线程去处理.一个socket连接一个处理线程(这个线程负责这个Socket连接的一系列数据传输操作).阻塞的原因在于:操 ...
- mysql练习题目试水50题,附建库sql代码
如果你没试过水的话,那一题一题地每一题都敲一遍吧.不管它们对你看来有多么简单. 建库代码 部分题目答案在末尾,可用ctrl f 搜索题号. 作业练习——学生-选课 表结构 学生表: Student ...
- 移动端web整理 移动端问题总结,移动web遇到的那些坑
meta基础知识 H5页面窗口自动调整到设备宽度,并禁止用户缩放页面 忽略将页面中的数字识别为电话号码 忽略Android平台中对邮箱地址的识别 当网站添加到主屏幕快速启动方式,可隐藏地址栏,仅针对i ...
- 清除mac中自动记录的git用户名和密码
应用程序-实用工具-双击钥匙串-右上角搜索github-右击选项删除
- Python入门之基础day1
一.引子 1. 什么是编程语言? 编程语言就是人与计算机沟通的介质 2.什么是编程? 编程就是人把自己想命令计算机干的事情通过编程语言翻译出来并写到文件里去 为什么要编程? 编程的目的就是为了让计算机 ...