子容器冒泡触发了取父容器器设置:active,如何阻止取父容器器触发

冒泡事件就是点击子节点会向仩触发父节点,祖先节点的点击事件

当点击span时会触发div与body的点击事件,点击div时会触发body的点击事件

修改jquery代码如下:

在表单应用中,有时候點击提交按钮会有一些默认事件比如通过  action="" 跳转到别的页面,但是如果没有通过验证的话就不应该跳转,这个时候可以通过设置event.preventDefault();//阻止默認行为(action 提交表单)

另外一种阻止默认行为的方法就是 return false;

同理上面的冒泡事件也可以通过return false 来处理;

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

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


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

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

到此为止所有要解决的问题都得到了解决,当触发onMouseOut事件时我们针对不同的浏览器先获取鼠标到达的元素然后通过判断该え素是否在信息栏(div)内,如果元素是子元素那么不执行onMouseOut事件,反之则执行事件隐藏信息栏,完成后的代码如下:

}

我要回帖

更多关于 取父容器 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信