首页前端开发HTML两个div叠加触发事件发生闪烁问题的解决方法

两个div叠加触发事件发生闪烁问题的解决方法

时间2024-01-24 05:55:45发布访客分类HTML浏览580
导读:收集整理的这篇文章主要介绍了两个div叠加触发事件发生闪烁问题的解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 当鼠标移到div1上的时候,会出现div2。出现时div2在div1的上面,div2在出现后发生闪烁的问题...
收集整理的这篇文章主要介绍了两个div叠加触发事件发生闪烁问题的解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。

当鼠标移到div1上的时候,会出现div2。出现时div2在div1的上面,div2在出现后发生闪烁的问题。

于是开始找问题根源,发现原来是因为当我们触发div1的时候,div2出现,但是div2是存在于div1上面的,所以当div2出现后,会又一次触发下面div1的事件。通常我们可能给的事件是mouseover和mouseout,因为两个div叠加,div2出现时会多次触发div1的事件,所以就会发生闪烁问题。

解决:

1.一开始换mouseenter和mouseleave,但是发现还是一样的问题。

注:

mouseover()与mouseout()   表示鼠标移入和移出的时候触发,穿过子元素也会触发

mouseenter()和mouseleave()   表示鼠标穿过和穿出时候触发,穿过子元素不会触发
 

2.然后又添加e.stopPRopagation(); 阻止冒泡和e.preventDefault(); 阻止默认事件,还是没有对症。

注:

e.stopPropagation();    //阻止冒泡之后,就不会形成冒泡向上传递了。

e.preventDefault();     //阻止默认行为

3.最后换为切换事件toggle切换事件也不顶事儿。

4.最终,如果想用js解决这个问题可能不容易,用js基本都会发生闪烁问题。那么我们使用css方式是不是可以解决呢?网上查了很多资料,发现也有很多人遇到这个问题,使用的是css中的hover来解决的。

具体使用方法:

给两个div的父元素,也就是共同包裹两个div的盒子一个hover,当父元素hover时,div2的样式设置为display:block; 于是就顺利解决了这个问题,不会再出现闪烁问题。

下面上代码:

htML部分:

XML/HTML Code复制内容到剪贴板
  1. div class="fudiv">   
  2.         span class="div1"> img src="img/jixinjia-partner1.jpg" alt=""/> /span>   
  3.         div class="div2">   
  4.                  div class="box6"> img src="img/qr-code-bg1%20(1).jpg" alt="p"/> /div>   
  5.                  p> 扫码有奖/p>   
  6.         /div>   
  7. /div>   

css部分:

CSS Code复制内容到剪贴板
  1. .fudiv:hover .div2 {   
  2.          displayblock;   
  3. }   
  4.   
  5. .div2{   
  6.           displaynone;   
  7. }   

原本jquery部分,这种方式会出现闪烁问题

JavaScript Code复制内容到剪贴板
  1. script>   
  2.     $(document).ready(   
  3.             function(){   
  4.                 $(".div1").mouseover(   
  5.                         function(e){   
  6.                             e.stopPropagation();   
  7.                             $(".div2").show();   
  8.                         }   
  9.                 );   
  10.                 $(".div1").mouseout(   
  11.                         function(e){   
  12.                             e.stopPropagation();   
  13.                             $(".div2").toggle();   
  14.                         }   
  15.                 );   
  16.             }   
  17.     );   
  18. /script>   

以上这篇两个div叠加触发事件发生闪烁问题的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

原文地址:http://www.cnblogs.com/hanyining/p/5470581.html

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

div叠加触发事件

若转载请注明出处: 两个div叠加触发事件发生闪烁问题的解决方法
本文地址: https://pptw.com/jishu/585087.html
HTML5本地存储之Web Storage应用介绍 html5 application cache遇到的严重问题

游客 回复需填写必要信息