layer弹出框覆盖在触发mouseenter 和 mouseleave事件元素上的一种解决方法

本文主要是介绍layer弹出框覆盖在触发mouseenter 和 mouseleave事件元素上的一种解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述:
需求是在table中有告警数据,当鼠标移动到告警数据上,弹出该告警数据关联的信息(关联数据也是表格形式),移开鼠标时,弹出框关闭。
但是在关闭时有这种情况,当弹出框在告警数据的上层时,移动鼠标,先触发mouseleave事件,关闭弹出框,由于弹出框关闭,鼠标回到告警数据上,又弹出,一直循环。


目前能想到的解决方案是:在触发mouseleave事件时,判断鼠标位置,是否在弹出框div(layer中的自定义页面)的区域,如果是在该区域,则给div添加mouseleave事件,离开div时关闭div。


<table ><tr><th  class="test">xxx</th><td>yyy</td></tr>
</table>
<div id="tableDivId"><table ><tr><td>xxx</td><td>yyy</td></tr><tr><td>xxx</td><td>yyy</td></tr>
</table>	
</div>

$(".test").each(function(){var thSpan = "<span>" + $(this).text() +"</span>";$(this).html(thSpan);var tdSpan = "<span>" + $(this).next().text() +"</span>";$(this).next().html(tdSpan);$(this).children().on("mouseenter",function(){var tableDivId = $(this).parent().attr("dataKey").replace(".","_");layer.closeAll();layer.open({type: 1,skin: 'layui-layer-demo', //样式类名closeBtn: 1, //不显示关闭按钮anim: 2,shade: 0,shadeClose: true, //开启遮罩关闭area: '70%',offset:'50px',content: $("#"+tableDivId).html()})});$(this).children().on("mouseleave",function(e){//"#layui-layer"+layer.index  根据layer.index  找到对应显示的弹出框自定义页面var width = $("#layui-layer"+layer.index).width();var height = $("#layui-layer"+layer.index).height();var offset = $("#layui-layer"+layer.index).offset();var top = offset.top;var left = offset.left;//鼠标位置var mouseX = e.pageX;var mouseY = e.pageY;if((mouseX > left && mouseX < left+width) && (mouseY > top && mouseY < top+height)	){$("#layui-layer"+layer.index).on("mouseleave",function(e){layer.closeAll();});}else{layer.closeAll();}	});})


这篇关于layer弹出框覆盖在触发mouseenter 和 mouseleave事件元素上的一种解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1080404

相关文章

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

idea中project的显示问题及解决

《idea中project的显示问题及解决》:本文主要介绍idea中project的显示问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录idea中project的显示问题清除配置重China编程新生成配置总结idea中project的显示问题新建空的pr

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Nginx 413修改上传文件大小限制的方法详解

《Nginx413修改上传文件大小限制的方法详解》在使用Nginx作为Web服务器时,有时会遇到客户端尝试上传大文件时返回​​413RequestEntityTooLarge​​... 目录1. 理解 ​​413 Request Entity Too Large​​ 错误2. 修改 Nginx 配置2.1

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1

sql语句字段截取方法

《sql语句字段截取方法》在MySQL中,使用SUBSTRING函数可以实现字段截取,下面给大家分享sql语句字段截取方法,感兴趣的朋友一起看看吧... 目录sql语句字段截取sql 截取表中指定字段sql语句字段截取1、在mysql中,使用SUBSTRING函数可以实现字段截取。例如,要截取一个字符串字

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题

《Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题》:本文主要介绍Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录一、前言二、系统架构检测三、卸载旧版 Go四、下载并安装正确版本五、配置环境变量六、验证安装七、常见

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr

Python处理超大规模数据的4大方法详解

《Python处理超大规模数据的4大方法详解》在数据的奇妙世界里,数据量就像滚雪球一样,越变越大,从最初的GB级别的小数据堆,逐渐演变成TB级别的数据大山,所以本文我们就来看看Python处理... 目录1. Mars:数据处理界的 “变形金刚”2. Dask:分布式计算的 “指挥家”3. CuPy:GPU