javascript中onmouse事件在div中失效问题的解决方法
2023-06-13 09:14:32 时间
也就是说,移到对象的子对象上,也算onmouseout了。但这往往会达不到我们想要的预期效果。这是由于javascript自身的冒泡特性导致的(即在子元素上触发了事件,并冒泡到了父元素-堆栈后进先出算法)。今天在网上搜了一下,找了以下的解决办法(兼容IE和Firefox)。
在IE下解决问题很简单,用onMouseEnter、onMouseLeave来代替onMouseOver、onMouseOut就行了,他们的作用基本相同,但前者不会发生冒泡(如果用jQuery的event事件,只要绑定mouseleave、mouseenter即可)。但firefox下并没有onMouseEnter、onMouseLeave这两个事件。那么只能使用纯js来解决IE及Firefox的兼容性问题了:
原理:通过判断触发onMouseOut事件后,鼠标到达的元素是不是包含在父元素信息栏(div)内,如果是就表示鼠标还在信息栏(div)上,则不隐藏。如果否就表示鼠标真的移出了信息栏(div),那么信息栏就要隐藏。
复制代码代码如下:
在IE下解决问题很简单,用onMouseEnter、onMouseLeave来代替onMouseOver、onMouseOut就行了,他们的作用基本相同,但前者不会发生冒泡(如果用jQuery的event事件,只要绑定mouseleave、mouseenter即可)。但firefox下并没有onMouseEnter、onMouseLeave这两个事件。那么只能使用纯js来解决IE及Firefox的兼容性问题了:
原理:通过判断触发onMouseOut事件后,鼠标到达的元素是不是包含在父元素信息栏(div)内,如果是就表示鼠标还在信息栏(div)上,则不隐藏。如果否就表示鼠标真的移出了信息栏(div),那么信息栏就要隐藏。
//首先来获取触发onMouseOut事件的元素,IE下通过event的toElement属性来获得,firefox下通过event的relatedTarget属性来获得。
IE:event.toElement,Firefox:event.relatedTarget(注意:Firefox下的event须通过在函数调用时传入,而IE下的event则可以直接通过window.event系统对象来获得)
//① 接下来就是判断获取的元素是否是主体div的子元素(IE下可以通过元素的obj.contains(element)方法来判断,但Firefox下没有这个方法,所以需要给firefox定义元素的obj.contains()方法)。
代码如下:
if(typeof(HTMLElement)!="undefined")//给firefox定义contains()方法,IE已经系统自带有这个方法了
{
HTMLElement.prototype.contains=function(obj){
while(obj!=null&&typeof(obj.tagName)!="undefind"){//通过循环对比来判断是不是obj的父元素
if(obj==this){returntrue;}
obj=obj.parentNode;
}
returnfalse;
};
}
//② 获取和判断搞定后,我们就可以通过判断IE和Firefox来针对处理了,通过navigator.userAgent来判断浏览器类型:
if(navigator.userAgent.indexOf("MSIE")>0){
return"MSIE";
}
if(navigator.userAgent.indexOf("Firefox")>0){
return"Firefox";
}
//③ 到此为止所有要解决的问题都得到了解决,当触发onMouseOut事件时,我们将针对不同的浏览器先获取鼠标到达的元素,然后通过判断该元素是否在信息栏(div)内,如果元素是子元素,那么不执行onMouseOut事件,反之则执行事件,隐藏信息栏,完成后的代码如下:
functionhideMsgBox(theEvent){//theEvent用来传入事件,Firefox的方式
if(theEvent){
varbrowser=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;//结束函数
}
}
}
/*要执行的操作(如:隐藏)*/
document.getElementById("MsgBox").style.display="none";
……
}
//④ 在信息栏(Div)上设置onMouseOut=hideMsgBox(event)来调用。
另外,通过设置window.event.cancelBubble=true(IE),event.stopPropagation()event.preventDefault()(Firefox)也可以解决问题,但是需要遍历所有子元素,影响效率,所以还是在触发onMouseOut事件时再进行上述判断分别处理比较合适。
相关文章
- Day5 JavaScript(三)事件、表单验证以及初识jQuery详解编程语言
- JavaScript 获取客户端计算机硬件及系统信息详解编程语言
- 在JavaScript文件中读取properties文件的方法详解编程语言
- javascript中两种基本常用排序算法分析详解编程语言
- javascript下给元素添加事件的方法与代码
- Javascript循环绑定事件的示例代码
- Javascript客户端将指定区域导出到Word、Excel的代码
- javascript的onchange事件与jQuery的change()方法比较
- JavaScript设计模式富有表现力的Javascript(一)
- JavaScript高级程序设计(第3版)学习笔记6初识js对象
- 在ASP.NET中使用JavaScript脚本的方法
- javascript页面加载完执行事件代码
- javascript中的事件代理初探
- javascript事件函数中获得事件源的两种不错方法
- JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
- JavaScript函数获取事件源的小例子
- 浅谈javascript中createElement事件
- JavaScript学习笔记之语句
- JavaScript截取字符串的2个函数介绍