onmouseover和onmouseout的一些问题思考 |
一个DIV层,当鼠标移进的时候会触发onmouseover,移出的时候会触发onmouseout 。 ![]() 很简单的逻辑,这也是我们想要的!但随之烦恼也就来了:onmouseover并不会只在移进时才触发,onmouseout也不会只在移出时才触发!鼠标在DIV里面移动时也会可能触发onmouseover或onmouseout 。 ![]() 在上图中,对于A来说:当鼠标进入A(路径1′)时那么就会触发A的onmouseover事件;接着鼠标移动到B(路径2′),此时A会触发onmouseout(先)和onmouseover(后)事件 。 由此可见,如果HTML元素(‘A层)内还有其他元素(‘B,C层),当我们移动到这些内部的元素时就会触发最外层(‘A层)的onmouseout和onmouseover事件 。 这两个事件的触发表现真的就是你想要的吗?也许你需要一个只在移进时才触发的,一个只在移出时才触发的事件,不管其内部是否还有其他元素…. 解决方案 在IE下确实有你需要的两个这样事件:onmouseenter 和 onmouseleave 。但很不幸FF等其他浏览器并不支持,只好模拟实现: 复制代码 代码如下: document.getElementById(...).onmouseover = function(e){ if( !e ) e = window.event; var reltg = e.relatedTarget ? e.relatedTarget : e.fromElement; while( reltg && reltg != this ) reltg = reltg.parentNode; if( reltg != this ){ // 这里可以编写 onmouseenter 事件的处理代码 } } document.getElementById(...).onmouseout = function(e){ if( !e ) e = window.event; var reltg = e.relatedTarget ? e.relatedTarget : e.toElement; while( reltg && reltg != this ) reltg = reltg.parentNode; if( reltg != this ){ // 这里可以编写 onmouseleave 事件的处理代码 } } 备注: W3C在mouseover和mouseout事件中添加了relatedTarget属性 •在mouseover事件中,它表示鼠标来自哪个元素 •在mouseout事件中,它指向鼠标去往的那个元素 而Microsoft在mouseover和mouseout事件中添加了两个属性 •fromElement,在mouseover事件中表示鼠标来自哪个元素 •toElement,在mouseout事件中指向鼠标去往的那个元素 |