好久没有更新博客了,今天搞了快一天的网页自适应,头晕。。。因为最近开始做项目,项目中需要用到图表方面的知识,于是乎接触到了echarts,所以其实我也算是新手了。只是近几天弄了很久的关于图表隐藏之后再次显示,却无法显示出来的问题。在网上也搜寻了好久。都没有特别对口的答案,echarts图表一直是显示的到还没发现有什么异常,只是如果你想要做类似选项卡切换图表的隐藏和显示的话,这个问题就不得不直视了。废话讲了那么多,开始说解决方法。

在解决之前需要知道原因:相信网上一搜,基本上就可以确定大多数的情况都是一样的,那就是echarts图表隐藏之后再次显示可能会涉及到没有高宽度的问题,或者你可以右击检查一下你的图表的宽度此时是0还是NaN!!!  那么知道没有高宽度,那么就需要在display:block显示之前给它一个宽高,这样就没有问题了。那么这个宽高的设置可以有两种设置方法(目前我可以知道的想到的),一是在行间设置宽高,这样的宽高度就是固定的,永远都是那么多,比如说这样

这样子设置之后的话,可通过设置一个按钮来显示图表,那么显示是成功了,但是如果想要自适应窗口大小,跟随窗口大小变化而变化,那么这种方式就不可取了,就需要使用一种相对的宽高了,你有没有想到呢?那就是当前窗口的大小了,window.innerHeight   window.innerWidth;那么如果是两个图表,像我这样的话,可以封装一个函数来设置图表的宽和高,像这样:

但是我先说我这种写法比较死,高度没有用窗口的高度,宽度的话窗口宽度太宽了,所以我大概减了80px;没有把对象抽象出来当成参数来传递,所以不具有代码的复用性,大家可以根据这个自行封装一个复用性高的函数,那么这就是为两个图表设置好了宽度和高度,接下来就是在显示之前调用一下该函数,那么就意味着在显示之前我的图表有了宽度和高度,那么就可以显示了,如果想要改变窗口大小的时候图表也跟着变化的话,那么就由需要做一点小工作,如下:

后边的两个语句的意思是说(因为我有两个按钮,用于切换两个图表,那么每次按钮点击的时候都会自动去触发window.onresize事件,而不用等到我手动的去拖动窗口的时候,才去触发,这样的话就可以实现随时的自适应大小,而不会出现点击第一个按钮改变窗体大小之后,再去点击第二个按钮,会发现第二个按钮对应的图表没有根据之前变化的窗体大小而变化),所以要加上这么一句自动替我们触发resize事件,这是jquery的语法,不太清楚的童鞋可以百度一下。最后,还有一点:

这块代码就是自适应窗体大小的代码,这句和上面的trigger那句不冲突不重复的,一个是改变窗体大小,一个是点击按钮,两个都需要触发resize事件。

差不多就这些玩意儿了,大家可以根据自己的情况做相应的小调整,基本上就可以解决大多数这种类型的状况了。

echarts隐藏之后的显示问题的更多相关文章

  1. echarts —— tooltip 鼠标悬浮显示提示框属性

    最近一直在使用echarts,当然也被其中的各种属性整的头大,记录一下其中遇到的问题. tooltip:鼠标悬浮时显示的提示框. 今天想要记录的是[自定义提示框的内容],如下图,鼠标悬浮时提示框内显示 ...

  2. 【extjs】 Extjs中的Ext.grid.Panel隐藏列会显示在表头中解决方法

    在Extjs中的GridPanel会有这样的情况,隐藏列会显示在menuDisabled中,但是这个一般没有什么用处,只是用于后台取值的作用,感兴趣的朋友可以了解下啊,希望本文对你有所帮助   在Ex ...

  3. 利用JS做到隐藏div和显示div

    div的visibility可以控制div的显示和隐藏,但是隐藏后页面显示空白 style="visibility: none;" document.getElementById( ...

  4. [置顶] echarts x轴文字显示不全(xAxis文字倾斜比较全面的3种做法值得推荐)

    echarts x轴标签文字过多导致显示不全 如图: 解决办法1:xAxis.axisLabel 属性 axisLabel的类型是object ,主要作用是:坐标轴刻度标签的相关设置.(当然yAxis ...

  5. echarts x轴文字显示不全解决办法

    标题:echarts x轴文字显示不全(xAxis文字倾斜比较全面的3种做法值得推荐):http://blog.csdn.net/kebi007/article/details/68488694

  6. [WPF疑难] 模式窗口被隐藏后重新显示时变成了非模式窗口

    原文:[WPF疑难] 模式窗口被隐藏后重新显示时变成了非模式窗口 [WPF疑难] 模式窗口被隐藏后重新显示时变成了非模式窗口 周银辉 现象: 大家可以试试下面这个很有趣但会带来Defect的现象:当我 ...

  7. echarts柱状图坐标文字显示不完整解决方式

    echarts柱状图坐标文字显示不完整解决方式 本文转载自:https://jingyan.baidu.com/article/ab69b2707a9aeb2ca7189f0c.html echart ...

  8. JQuery 简单的文字超出部分隐藏下拉显示

    HTML代码: <body> <div class="txt_bos"><!--在每一个放置文字的class外面包一个div,以便设置动画样式用,同样 ...

  9. text-overflow:ellipsis实现超出隐藏时省略号显示

    text-overflow:ellipsis;要达到的效果是:文字超出容器宽度时,文字被隐藏的文字用省略号代替.所以该属性只能用于块状元素或行内块元素中,对行内元素是不起作用的. 一般和white-s ...

随机推荐

  1. linux磁盘用满的两种情况

    首先查看分区的内存使用情况和inode使用情况 第一种情况,内存用完: 我们拿分区sdb5来做实验 查看内存使用情况和inode使用情况: 第二种情况:inode使用完 我们在该分区下创建很多空文件 ...

  2. CentOS7 yum方式安装 MongoDB 3.4 复制集

    CentOS7 yum方式安装 MongoDB 3.4 环境.准备 Centos7 系统 配置MongoDB的yum源,添加文件/etc/yum.repos.d/mongodb-org-3.4.rep ...

  3. 手淘的移动端适配方案flexible

    基于 vue-cli 配置手淘的 lib-flexible + rem,实现移动端自适应 安装 flexible npm install lib-flexible --save 引入 flexible ...

  4. mac 系统安装VM虚拟机打开时报错,提示不是虚拟磁盘的解决方式。

    最近刚买的苹果系统,不太会用,装了个虚拟机vmware fusion,好不容易把需要的软件装好,然后不知道是我操作了哪里,今天再次打开虚拟机的时候打不开了,报错提示找不到磁盘文件(虚拟磁盘-00000 ...

  5. Python -- Gui编程 -- Qt库的使用 -- 菜单与对话框

    1.菜单 import sys from PyQt4 import QtCore, QtGui class MyWindow(QtGui.QMainWindow): def __init__(self ...

  6. tomcat 日志详解

    1 tomcat  日志详解 1.1  tomcat 日志配置文件 tomcat 对应日志的配置文件:tomcat目录下的/conf/logging.properties. tomcat 的日志等级有 ...

  7. vscode 常用配置

    { "workbench.iconTheme": "vscode-icons", "editor.tabSize": 2, "ed ...

  8. 虚拟化明星——深挖轻量级容器docker

    docker是一个轻量级容器,属于操作系统层面的虚拟化技术,封装了文件系统(AUFS)以及网络互联,进程隔离等特性. 传统虚拟化架构: docker虚拟化架构: 可以看出,docker是没有Guest ...

  9. JavaScript初级面试题

    前面几题是会很基础,越下越有深度. 初级Javascript: 1.JavaScript是一门什么样的语言,它有哪些特点? 没有标准答案. 2.JavaScript的数据类型都有什么? 基本数据类型: ...

  10. Spring配置Quartz任务调度、及 ThreadPool 线程池

    ONE.除了引入 Spring 相关的 jar 包,还要引入 Quartz 的 jar 包 <dependency> <groupId>org.springframework& ...