IE6/7下面mouseover和mouseout鼠标事件的一些问题

[size=x-large]一.概述[/size]
[size=medium]
[list]
1.在IE6下面使用mouseover和mouseout事件时,如果被注册事件的元素下面有一些子元素,这时候如果鼠标在当前元素的子元素上滑动时,鼠标的事件也会被触发,我们就是想阻止这个中情形下面鼠标事件的触发。
[/list]
[list]
2.使用了mouseleave之后为什么鼠标没有移出元素区域,但是事件依然响应了呢?
[/list]
[list]
3.关于事件冒泡的一些注意点。
[/list]
[/size]
[size=x-large]二.问题的解释[/size]
[size=medium]
[list]
1.对于第一个问题,可以解释为是IE下面的一个BUG,目前尽量不要使用mouseover和mouseout事件,用mouseenter和mouseleave事件来代替这两个事件,可以防止上面问题的出现。
[/list]
[list]
2.遇见第一个问题之后,采用了mouseleave事件,但是我的效果还是没有达到,在IE6/7下面依然出现鼠标还没有移出去,但是事件却触发了,仔细看了看触发事件的原因是被这个元素盖住的元素下面的一些元素注册了鼠标移动上去的事件,由于当前元素的背景是透明的,导致下面元素的事件可以在当前元素的上移动鼠标时被触发,这样当前元素的鼠标滑出事件也就被触发了。解决的方法是设置当前元素的背景,把当前元素变成非透明的就可以了。
[/list]
[list]
3.关于事件冒泡,加入一个div我们注册了click事件,然后在这个div内部又有一个嵌套的div我们也注册了click事件,这时候如果我们点击内部的div之后,不仅会触发内部div元素的click事件,也会触发外部div的click事件,这就是所谓的事件冒泡,当前可以在内部元素的事件回调函数中去阻止事件的派发,防止出现事件冒泡。在平时开发的过程中要注意一下这一点。
[/list]
[/size]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值