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代码优化之基本事件
Nov 01 Javascript
js中的push和join方法使用介绍
Oct 08 Javascript
javascript常用的正则表达式实例
May 15 Javascript
js实现密码强度检测【附示例】
Mar 30 Javascript
Ext JS框架中日期函数的用法及日期选择控件的实现
May 21 Javascript
微信小程序 es6-promise.js封装请求与处理异步进程
Jun 12 Javascript
微信小程序倒计时功能实例代码
Jul 17 Javascript
Vue中的vue-resource示例详解
Nov 02 Javascript
详解nuxt路由鉴权(express模板)
Nov 21 Javascript
对于防止按钮重复点击的尝试详解
Apr 22 Javascript
vue实现淘宝购物车功能
Apr 20 Javascript
vue video和vue-video-player实现视频铺满教程
Oct 30 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在字符串中查找另一个字符串
2008/11/19 PHP
PHP设计模式之观察者模式实例
2016/02/22 PHP
Joomla简单判断用户是否登录的方法
2016/05/04 PHP
js技巧--转义符"\"的妙用
2007/01/09 Javascript
js 处理数组重复元素示例代码
2013/12/27 Javascript
Javascript基础教程之if条件语句
2015/01/18 Javascript
jQueryMobile之Helloworld与页面切换的方法
2015/02/04 Javascript
ECMAScript6中Map/WeakMap详解
2015/06/12 Javascript
Vue.js系列之项目搭建(1)
2017/01/03 Javascript
JavaScript函数基础详解
2017/02/03 Javascript
Vue.js中组件中的slot实例详解
2017/07/17 Javascript
在Debian(Raspberry Pi)树莓派上安装NodeJS的教程详解
2017/09/19 NodeJs
动态统计当前输入内容的字节、字符数的实例详解
2017/10/27 Javascript
使用veloticy-ui生成文字动画效果
2018/02/08 Javascript
在vue中使用css modules替代scroped的方法
2018/03/10 Javascript
深入浅析Vue.js计算属性和侦听器
2018/05/05 Javascript
基于Vue 2.0 监听文本框内容变化及ref的使用说明介绍
2018/08/24 Javascript
JavaScript表格隔行变色和Tab标签页特效示例【附jQuery版】
2019/07/11 jQuery
微信小程序 textarea 层级过高问题简单解决方案
2019/10/14 Javascript
PYTHON压平嵌套列表的简单实现
2016/06/08 Python
pygame加载中文名mp3文件出现error
2017/03/31 Python
PyQt5实现简单数据标注工具
2019/03/18 Python
Python3使用Matplotlib 绘制精美的数学函数图形
2019/04/11 Python
Python格式化字符串f-string概览(小结)
2019/06/18 Python
Python Numpy计算各类距离的方法
2019/07/05 Python
对pytorch的函数中的group参数的作用介绍
2020/02/18 Python
Python图像处理之膨胀与腐蚀的操作
2021/02/07 Python
Lowe’s加拿大:家居装修、翻新和五金店
2019/12/06 全球购物
一套PHP的笔试题
2013/05/31 面试题
学生学习总结的自我评价
2013/10/22 职场文书
求职自荐信怎么写
2014/03/06 职场文书
保密承诺书
2014/03/27 职场文书
12岁生日演讲稿
2014/05/14 职场文书
纪念九一八事变演讲稿:青少年应树立远大理想
2014/09/14 职场文书
2014年会计人员工作总结
2014/12/10 职场文书
Pytest实现setup和teardown的详细使用详解
2021/04/17 Python