onmouseover和onmouseout的烦人问题

一个DIV层,当鼠标移进的时候会触发onmouseover,移出的时候会触发onmouseout。

《onmouseover和onmouseout的烦人问题》

 

很简单的逻辑,这也是我们想要的!但随之烦恼也就来了:onmouseover并不会只在移进时才触发,onmouseout也不会只在移出时才触发!鼠标在DIV里面移动时也会可能触发onmouseover或onmouseout。

《onmouseover和onmouseout的烦人问题》

 

在上图中,对于’A’来说:当鼠标进入’A'(路径’1′)时那么就会触发’A’的onmouseover事件;接着鼠标移动到’B'(路径’2′),此时’A’会触发onmouseout(先)和onmouseover(后)事件。

由此可见,如果HTML元素(‘A’层)内还有其他元素(‘B’,’C’层),当我们移动到这些内部的元素时就会触发最外层(‘A’层)的onmouseout和onmouseover事件。

这两个事件的触发表现真的就是你想要的吗?也许你需要一个只在移进时才触发的,一个只在移出时才触发的事件,不管其内部是否还有其他元素….

 

解决方案

在IE下确实有你需要的两个这样事件:onmouseenter 和 onmouseleave。但很不幸FF等其他浏览器并不支持,只好模拟实现:

[javascript] 
view plain
copy

  1. document.getElementById(‘…’).onmouseover = function(e){  
  2.     if( !e ) e = window.event;  
  3.     var reltg = e.relatedTarget ? e.relatedTarget : e.fromElement;  
  4.     while( reltg && reltg != this ) reltg = reltg.parentNode;  
  5.     if( reltg != this ){  
  6.         // 这里可以编写 onmouseenter 事件的处理代码  
  7.     }  
  8. }  
  9.   
  10.    
  11.   
  12. document.getElementById(‘…’).onmouseout = function(e){  
  13.     if( !e ) e = window.event;  
  14.     var reltg = e.relatedTarget ? e.relatedTarget : e.toElement;  
  15.     while( reltg && reltg != this ) reltg = reltg.parentNode;  
  16.     if( reltg != this ){  
  17.         // 这里可以编写 onmouseleave 事件的处理代码  
  18.    }  
  19. }  

 

 

备注:

W3C在mouseover和mouseout事件中添加了relatedTarget属性

  • 在mouseover事件中,它表示鼠标来自哪个元素
  • 在mouseout事件中,它指向鼠标去往的那个元素

而Microsoft在mouseover和mouseout事件中添加了两个属性

  • fromElement,在mouseover事件中表示鼠标来自哪个元素
  • toElement,在mouseout事件中指向鼠标去往的那个元素
    原文作者:道路修建问题
    原文地址: https://blog.csdn.net/99guo/article/details/42119437
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞