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


Posted in Javascript onJanuary 09, 2012

也就是说,移到对象的子对象上,也算onmouseout了。但这往往会达不到我们想要的预期效果。这是由于javascript自身的冒泡特性导致的(即在子元素上触发了事件,并冒泡到了父元素-堆栈后进先出算法)。今天在网上搜了一下,找了以下的解决办法(兼容IE和Firefox)。
在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) { 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; //结束函数 
} 
} 
} 
/*要执行的操作(如:隐藏)*/ 
document.getElementById('MsgBox').style.display='none' ; 
…… 
} 
// ④ 在信息栏(Div)上设置onMouseOut=hideMsgBox(event)来调用。

另外,通过设置window.event.cancelBubble = true (IE) ,event.stopPropagation() event.preventDefault() (Firefox) 也可以解决问题,但是需要遍历所有子元素,影响效率,所以还是在触发onMouseOut事件时再进行上述判断分别处理比较合适。
Javascript 相关文章推荐
jQuery 选择器理解
Mar 16 Javascript
js 获取Listbox选择的值的代码
Apr 15 Javascript
javascript常用方法、属性集合及NodeList 和 HTMLCollection 的浏览器差异
Dec 25 Javascript
JavaScript基本编码模式小结
May 23 Javascript
关于eval 与new Function 到底该选哪个?
Apr 17 Javascript
JQueryiframe页面操作父页面中的元素与方法(实例讲解)
Nov 19 Javascript
JS+CSS实现滑动切换tab菜单效果
Aug 25 Javascript
AngularJS中处理多个promise的方式
Feb 02 Javascript
VUEJS实战之利用laypage插件实现分页(3)
Jun 13 Javascript
Html5 js实现手风琴效果
Apr 17 Javascript
jQuery实现判断控件是否显示的方法
Jan 11 Javascript
vue、react等单页面项目应该这样子部署到服务器
Jan 03 Javascript
jQuery 阴影插件代码分享
Jan 09 #Javascript
jquery ajax 同步异步的执行 return值不能取得的解决方案
Jan 08 #Javascript
玩转jQuery按钮 请告诉我你最喜欢哪些?
Jan 08 #Javascript
分享几个超级震憾的图片特效
Jan 08 #Javascript
关于JAVASCRIPT urldecode URL解码的问题
Jan 08 #Javascript
JAVASCRIPT车架号识别/验证函数代码 汽车车架号验证程序
Jan 08 #Javascript
人人网javascript面试题 可以提前实现下
Jan 05 #Javascript
You might like
通过php添加xml文档内容的方法
2015/01/23 PHP
微信公众号实现会员卡领取功能
2017/06/08 PHP
PHP变量的作用范围实例讲解
2020/12/22 PHP
jquery 模式对话框终极版实现代码
2009/09/28 Javascript
Javascript学习笔记2 函数
2010/01/11 Javascript
jQuery编辑器KindEditor4.1.4代码高亮显示设置教程
2013/03/01 Javascript
javascript将数字转换整数金额大写的方法
2015/01/27 Javascript
JS实现的简洁纵向滑动菜单(滑动门)效果
2015/10/19 Javascript
原生javascript实现分享到朋友圈功能 支持ios和android
2016/05/11 Javascript
JS面试题---关于算法台阶的问题
2016/07/26 Javascript
jQuery EasyUI Accordion可伸缩面板组件使用详解
2017/02/28 Javascript
浅谈js中startsWith 函数不能在任何浏览器兼容的问题
2017/03/01 Javascript
ExtJs异步无法向外传值和赋值的完美解决办法
2017/06/14 Javascript
AngularJs实现聊天列表实时刷新功能
2017/06/15 Javascript
Vue实现带进度条的文件拖动上传功能
2018/02/23 Javascript
JS获取指定月份的天数两种实现方法
2018/06/22 Javascript
js实现同一个页面,多个enter事件绑定的示例
2018/10/10 Javascript
vue input标签通用指令校验的实现
2019/11/05 Javascript
Python中为feedparser设置超时时间避免堵塞
2014/09/28 Python
用于统计项目中代码总行数的Python脚本分享
2015/04/21 Python
浅析python中的分片与截断序列
2016/08/09 Python
python kmeans聚类简单介绍和实现代码
2018/02/23 Python
运行django项目指定IP和端口的方法
2018/05/14 Python
解决pytorch多GPU训练保存的模型,在单GPU环境下加载出错问题
2020/06/23 Python
python 指定源路径来解决import问题的操作
2021/03/04 Python
The Hut美国/加拿大:英国领先的豪华在线百货商店
2019/03/26 全球购物
医学实习生自我鉴定
2013/12/12 职场文书
商务英语大学生职业生涯规划书范文
2014/01/01 职场文书
便利店投资的创业计划书
2014/01/12 职场文书
乡镇信息公开实施方案
2014/03/23 职场文书
C++程序员求职信范文
2014/04/14 职场文书
用人单位终止解除劳动合同证明书
2014/10/06 职场文书
2014年世界艾滋病日宣传活动总结
2014/11/18 职场文书
2014年幼儿园德育工作总结
2014/12/17 职场文书
4S店客服专员岗位职责
2015/04/07 职场文书
奖学金申请个人主要事迹材料
2015/11/04 职场文书