- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个网页显示启用了缩放类型“x”的 Highcharts 图表。图表 div 包裹在容器 div 中,例如:
<div class='chart-container'>
<div id='chart_0' class='chart'></div>
</div>
还有一个事件处理程序附加到图表容器上的“mouseup”事件,它通过切换 modalChart css 类将图表切换到模态视图,定义如下:
.modalChart {
position: fixed;
width: 100%;
height: 100%;
top: 0;
left: 0;
background: rgba(0, 0, 0, 0.7);
z-index: 999999;
}
.chart {
height: 300px;
}
.modalChart .chart {
height: 90%;
width: 90%;
max-width: none;
margin: 1em auto;
}
事件处理程序定义为:
$("body").on("mouseup", ".chart-container", function(){
$(this).toggleClass "modalChart"
$(".chart", this).highcharts().reflow()
});
我遇到的问题是,发生缩放时,“chart-container”上的 mouseup 事件先于 x 轴上的 setExtremes 事件触发。因此,每次用户使用缩放功能时都会切换模态视图。我该如何阻止这种情况发生?我希望用户能够在不切换模态视图的情况下进行缩放,并且能够单击图表来切换模态视图。
最佳答案
问题当然是“chart-container”上的“mouseup”事件首先触发,即使用户正在缩放,模态视图也会切换。为了防止这种情况,我们需要延迟模式切换并在必要时取消它。一种解决方案是使用 setTimeout(与全局变量相关联)延迟模式切换,然后在使用缩放功能时在适当的位置清除超时。
我将“chart-container”类的事件处理程序更改为:
$("body").on("mouseup", ".chart-container", function(){
chart = this
Application.modalTimeout = setTimeout(function(){
$(chart).toggleClass "modalChart";
$(".chart", chart).highcharts().reflow();
}, 100)
});
然后在图表上 xAxis 的 setExtremes 事件中取消 setTimeout:
xAxis: {
events: {
setExtremes: function(){
if (Application.modalTimeout)
{
return clearTimeout(vm.Analysis.modalTimeout);
}
}
}
}
关于javascript - 当还启用缩放时,如何使用 Highcharts 触发模态视图?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26611685/
阅读目录 1、视图介绍 2、创建视图 3、查询视图 4、修改视图 5、删除视图 6、检查选项
基于函数的视图你已经get了,基于类的视图get了吗?CBV本质不知道?点进来看源码分析~ Django 视图之FBV 与 CBV FBV(function base views) 基于函数的视图,就
SQLite 视图(View) 视图(View)只不过是通过相关的名称存储在数据库中的一个 SQLite 语句。视图(View)实际上是一个以预定义的 SQLite 查询形式存在的表的组合。 视图
视图 什么是视图?视图的作用是什么? 视图(view)是一种虚拟存在的表,是一个逻辑表,它本身是不包含数据的。作为一个select语句保存在数据字典中的。 通过视图,可以展现基表(用来创建视图
代码如下: CREATE OR REPLACE VIEW BLOG_V_ADMIN (ID,NICKNAME,SEX,EMAIL,
创建视图 视图包含应用的 HTML 代码,并将应用的控制器逻辑和表现逻辑进行分离。视图文件存放在 resources/views 目录中。下面是一个简单的视图示例:
加密测试的存储过程 ? 1
简介数据库快照 数据库快照,正如其名称所示那样,是数据库在某一时间点的视图。是SQL Server在2005之后的版本引入的特性。快照
一 ,mysql事务 MYSQL中只有INNODB类型的数据表才能支持事务处理。 启动事务有两种方法 (1) 用begin,rollback,commit来实现 复制代码代码如
前言 在日常开发中,存储数据的最常用的方式便是数据库了,其中最为著名的便是MySQL数据库,因它简便易于上手而且可扩展性强大,跨平台使得它广为使用。上一篇文章,我们讲到了它的安装,今天我们就来
1、视图 视图:VIEW,虚表,保存有实表的查询结果,实际数据不保存在磁盘 物化视图:实际数据在磁盘中有保存,加快访问,MySQL不支持物化视图 基表:视图依赖的表 视图中的数据事实上
事项开启和使用 ? 1
代码如下: create PROCEDURE sp_decrypt(@objectName varchar(50)) AS begin begin tran&
前言 在之前 《Oracle打怪升级之路一》中我们主要介绍了Oracle的基础和Oracle常用查询及函数,这篇文章作为补充,主要介绍Oracle的对象,视图、序列、同义词、索引等,以及PL/SQL编
我是一名优秀的程序员,十分优秀!