`

解决js中onMouseOut事件冒泡的问题

 
阅读更多

转自:http://blog.163.com/ak_74a/blog/static/470404072008530105542228/

 

 

前阵子为BS项目模板做了一个左侧滑动信息栏,效果类似于windows状态栏的自动隐藏效果,鼠标移进滑出,鼠标移出隐藏,浮动时不占用空间,也可以固定住占一块位置。做的过程中遇到一个问题,鼠标在信息栏内部移动时会触发onMouseOut事件,信息栏放在div中,内部有table、img、a等元素,看来是由于事件冒泡,子元素上触发了事件冒泡到了父元素,导致滑动时不断闪动,头晕眼花,于是着手解决问题。

 


在IE下解决问题很简单,用onMouseEnter、onMouseLeave来代替onMouseOver、onMouseOut就行了,他们的作用基本相同,前者不会发生冒泡。但是firefox下没有这两个事件,公司BS项目模板要同时兼容IE和firefox,没办法,只能再找别的方法(多浏览器分天下的年代,解决问题总是没那么简单......(/_\)!)

有一个在IE和firefox下都行得通的解决思路,通过判断触发onMouseOut事件后鼠标到达的元素是不是包含在父元素(信息栏Div)内,如果是就表示鼠标还在信息栏上,则不隐藏,如果否就表示鼠标真的移出了信息栏,那么信息栏隐藏,思路有了,那么就一步步来解决问题

首先来获取触发onMouseOut事件的元素,IE下event的属性toElement来获得,在firefox下变成了relatedTarget(很是折腾!)
IE:event.toElement    Firefox:event.relatedTarget(注意Firefox下event须要调用函数时传入)

接下来就是判断获取的元素是否是子元素,IE下通过元素的contains(Element)方法可以判断,同样的firefox下没有这个方法!!,不过可以给firefox下的元素定义contains()方法来解决问题,代码如下:

if(typeof(HTMLElement)!="undefined")   //给firefox定义contains()方法,ie下不起作用
  {  
      HTMLElement.prototype.contains=function(obj)  
      {  
          while(obj!=null&&typeof(obj.tagName)!="undefind"){ //通过循环对比来判断是不是obj的父元素
      if(obj==this)  return true;  
      obj=obj.parentNode;
     }  
          return false;  
      };  
  }
  

获取和判断搞定后,我们就可以通过判断IE和Firefox来针对处理了,通过navigator.userAgent来判断浏览器:
   if(navigator.userAgent.indexOf("MSIE")>0) {
        return "MSIE";
   }
   if(navigator.userAgent.indexOf("Firefox")>0){
        return "Firefox";
   }


到此为止所有要解决的问题都得到了解决,当触发onMouseOut事件时我们针对不同的浏览器先获取鼠标到达的元素,然后通过判断该元素是否在信息栏(div)内,如果元素是子元素,那么不执行onMouseOut事件,反之则执行事件,隐藏信息栏,完成后的代码如下:
 function hideMsgBox(theEvent){  //theEvent用来传入事件,Firefox的方式
         if (theEvent){
               var browser=navigator.userAgent;   //取得浏览器属性
               if (browser.indexOf("Firefox")>0){  //如果是Firefox
                   if (document.getElementById('MsgBox').contains(theEvent.relatedTarget)) {  //如果是子元素
                         return;   //结束函式
                        } 
                  } 
                  if (browser.indexOf("MSIE")>0){  //如果是IE
                         if (document.getElementById('MsgBox').contains(event.toElement)) {  //如果是子元素
                                return;  //结束函式
                          }
                   }
             }
            /*要执行的操作*/
 }

在信息栏(Div)上设置onMouseOut=hideMsgBox(event)来调用,圆满解决冒泡问题。
事实上通过设置
window.event.cancelBubble = true (IE)   event.stopPropagation()  event.preventDefault() (Firefox)
也可以解决问题,但是需要遍历所有子元素,影响效率,所以还是在触发onMouseOut事件时再进行上述判断分别处理比较合适。

分享到:
评论

相关推荐

    js下关于onmouseout、事件冒泡的问题经验小结.docx

    ### JavaScript 下关于 `onmouseout` 与事件冒泡的问题经验小结 #### 一、引言 在前端开发过程中,事件处理是不可或缺的一部分。其中,`onmouseout` 事件和事件冒泡机制尤为关键,它们涉及到用户交互以及页面元素...

    js下关于onmouseout、事件冒泡的问题经验小结

    问题是这样的:一个div元素要触发onmouseout事件,同时这个div内部还有子元素,于是当鼠标移动到该div的子元素上时,onmouseout事件也被触发了。在要做浮动层效果的时候会经常遇到这个问题。 解决方法一: 使用...

    onmouseover事件和onmouseout事件全面理解

    为了解决这个问题,W3C引入了`relatedTarget`属性,该属性在`mouseover`事件中表示鼠标来自哪个元素,在`mouseout`事件中表示鼠标去往哪个元素。通过检查`relatedTarget`,我们可以判断鼠标是否真正离开了父元素。 ...

    JavaScript每天必学之事件

    在JavaScript中,事件处理程序一般以“on”开头,如onclick、onmouseover、onmouseout等。事件处理程序的命名约定帮助开发者快速识别出哪个函数负责处理哪种类型的事件。 接下来,我们来理解什么是事件冒泡和捕获。...

    javascript中onmouse事件在div中失效问题的解决方法

    本文探讨了在使用JavaScript处理鼠标事件时,在div元素中可能会遇到的onmouseout事件失效的问题,并提供了兼容IE和Firefox两种浏览器的解决方案。在探讨之前,需要了解几个基础知识点: 1. JavaScript事件冒泡:当...

    JavaScript程序设计——事件处理实验报告.docx

    实验报告详细介绍了JavaScript事件处理的相关知识,这在Web开发中是非常关键的一部分,因为事件是用户与网页交互的主要方式。以下是对各个知识点的详细说明: 1. **JavaScript事件基本概念**: - **事件**:是用户...

    javascript mouseover、mouseout停止事件冒泡的解决方案

    为了解决跨浏览器的`mouseover`和`mouseout`事件冒泡问题,开发者们采用了各种方法。例如,可以利用W3C标准中的`relatedTarget`属性来获取与事件相关的元素。`relatedTarget`属性在`mouseover`事件触发时指向鼠标...

    js事件详解-0-1-2级模型.pdf

    标题提到的“js事件详解-0-1-2级模型”涉及到了JavaScript中事件的分层模型。JavaScript事件模型是前端开发中处理用户交互的核心机制之一,主要包括了事件捕获、目标阶段和事件冒泡三个阶段,这个模型被广泛地理解为...

    09JavaScript事件总结.docx

    在非标准IE8及以下版本中,事件对象存储在`window.event`属性中。以下代码展示了如何获取并使用事件对象: ```javascript var X = event.screenX; var Y = event.screenY; txt.innerHTML = "X=" + X + " Y" + Y; ``...

    JavaScript事件机制

    在JavaScript中,事件绑定是指将一个事件处理函数与特定的DOM元素关联起来的过程。这可以通过多种方式进行实现。 ##### 内联事件处理程序 这是一种较为简单的绑定方式,直接在HTML标签中通过`on事件名`属性来指定...

    javascript中window.event事件用法详解

    在JavaScript编程中,事件处理是一种基本且强大的机制,允许开发者响应用户与页面交互的不同事件。window.event对象是JavaScript中一个特殊的对象,它代表当前发生的事件的状态,包括触发事件的元素、鼠标位置和按键...

    头歌教学实践平台 Web前端开发基础 JavaScript学习手册十五:事件处理

    在JavaScript中,事件处理通常有两种方式:事件监听器(Event Listeners)和传统事件处理程序。传统事件处理程序是通过在HTML元素上直接设置`onclick`、`onmouseover`等属性来实现的,而事件监听器则是通过...

    js事件大全,看了都说好

    同时,JavaScript还支持事件冒泡、事件委托、事件阻止等高级概念,这些都是构建复杂交互功能的关键。在实际开发中,还可以利用事件监听器(如`addEventListener`和`removeEventListener`)来更灵活地管理和控制事件...

    JS event使用方法详解

    JavaScript中的事件处理通常遵循事件传播(冒泡和捕获)的机制。冒泡是指事件从最深的节点开始,然后逐级向上传播到根节点的过程。在捕获阶段,事件从根节点开始向下传播至目标节点。 对于键盘事件,分为keydown、...

    Javascript之event大全

    JavaScript中的Event是处理用户交互或浏览器事件的核心机制。Event对象包含了与事件相关的所有信息,如触发事件的元素、事件类型、按键状态等。在JavaScript中,事件可以是用户的行为,如点击按钮、滚动页面,或者是...

    js事件触发大全

    在JavaScript编程中,事件处理是与用户交互的重要手段之一。通过监听特定的事件,我们可以实现各种动态效果和响应式操作。本文将详细介绍一系列常见的JS事件及其触发场景,帮助开发者更好地理解和应用这些事件。 ##...

    第11章JAVASCRIPT事件和浏览器[参考].pdf

    JavaScript事件和浏览器交互是网页动态效果和用户互动的基础,它们使得网页从静态转变为动态,提升了用户体验。...在实际开发中,还可以结合DOM遍历、事件冒泡与事件委托等概念,进一步提升代码的效率和可维护性。

Global site tag (gtag.js) - Google Analytics