如何防止鼠标移出移入子元素触发mouseout和mouseover事件
2017-08-11 13:11
453 查看
我想实现的目标:当鼠标进入黑色框时,橙色框执行淡入动画;当黑色框范围移动的时候(即使经过粉色框,动画仍然不被触发);当鼠标移出的时候,橙色方块消失。
遇到的问题阐述:当鼠标移入黑色框的时候,橙色框执行淡入动画,但是当鼠标从黑色框经过粉色框的时候,橙色框就消失了,然后又执行一遍淡入动画。当鼠标从粉色框移出到黑色框的时候,橙色框的淡入动画又被执行。这不是我想要的。
初期代码:
?
首先我们解释一下原因,为什么会出现这些问题。
当鼠标从黑色框移到粉色框的时候,此时黑色框的mouseout的被触发,又由于事件冒泡,黑色框的mouseover事件随即被触发,所以实际上,橙色框先消失,然后立即执行淡入动画。这也就是我们看到的过程。
当鼠标从粉色框移到黑色框的时候,此时黑色框的mouseout又被触发(因为不论鼠标穿过被选元素或其子元素,都触发 mouseover 事件),同时mouseover也被触发,所以又出现了再次执行淡入效果的过程。
方法一:用mouseleave/mouseout代替mouseover/mouseout【最佳方法】
先看一下mouseout&mouseover与mouseleave&mouseenter用法上的区别
mouseover与mouseenter
不论鼠标指
edb8
针穿过被选元素或其子元素,都会触发 mouseover 事件。
只有在鼠标指针从元素外穿入被选元素(到元素内)时,才会触发 mouseenter 事件。
mouseout与mouseleave
不论鼠标指针离开被选元素还是任何子元素,都会触发 mouseout 事件。
只有在鼠标指针从元素内穿出被选元素(到元素外)时,才会触发 mouseleave 事件。
可以看一个简单的例子看看二者的区别
所以改进的代码可以为
?
方法二:利用e.stopPropagation()阻止事件进一步传播
e.stopPropagation()会终止事件在传播过程的捕获、目标处理或起泡阶段进一步传播。调用该方法后,该节点上处理该事件的处理程序将被调用,事件不再被分派到其他节点。
?
拓展思考:
1.如果子元素过多怎么办,难道每个都要去绑定e.stopPropagation()?
用jquery的一个选择器.children(),比如$('.parent').children()。获得匹配元素集合中每个元素的子元素。
以上所述就是本文的全部内容了,希望大家能够喜欢。
遇到的问题阐述:当鼠标移入黑色框的时候,橙色框执行淡入动画,但是当鼠标从黑色框经过粉色框的时候,橙色框就消失了,然后又执行一遍淡入动画。当鼠标从粉色框移出到黑色框的时候,橙色框的淡入动画又被执行。这不是我想要的。
初期代码:
?
当鼠标从黑色框移到粉色框的时候,此时黑色框的mouseout的被触发,又由于事件冒泡,黑色框的mouseover事件随即被触发,所以实际上,橙色框先消失,然后立即执行淡入动画。这也就是我们看到的过程。
当鼠标从粉色框移到黑色框的时候,此时黑色框的mouseout又被触发(因为不论鼠标穿过被选元素或其子元素,都触发 mouseover 事件),同时mouseover也被触发,所以又出现了再次执行淡入效果的过程。
方法一:用mouseleave/mouseout代替mouseover/mouseout【最佳方法】
先看一下mouseout&mouseover与mouseleave&mouseenter用法上的区别
mouseover与mouseenter
不论鼠标指
edb8
针穿过被选元素或其子元素,都会触发 mouseover 事件。
只有在鼠标指针从元素外穿入被选元素(到元素内)时,才会触发 mouseenter 事件。
mouseout与mouseleave
不论鼠标指针离开被选元素还是任何子元素,都会触发 mouseout 事件。
只有在鼠标指针从元素内穿出被选元素(到元素外)时,才会触发 mouseleave 事件。
可以看一个简单的例子看看二者的区别
所以改进的代码可以为
?
e.stopPropagation()会终止事件在传播过程的捕获、目标处理或起泡阶段进一步传播。调用该方法后,该节点上处理该事件的处理程序将被调用,事件不再被分派到其他节点。
?
1.如果子元素过多怎么办,难道每个都要去绑定e.stopPropagation()?
用jquery的一个选择器.children(),比如$('.parent').children()。获得匹配元素集合中每个元素的子元素。
以上所述就是本文的全部内容了,希望大家能够喜欢。
相关文章推荐
- 如何防止鼠标移出移入子元素触发mouseout和mouseover事件
- 为什么鼠标还没完全移出就触发元素的mouseout事件
- 如何避免鼠标移入子级触发父级的移出事件(两种方法)
- android中按电源键锁屏然后解锁导致Activity调用onDestory以及如何防止锁屏 翻转屏幕也会触发的情况
- mouseover和mouseout事件在鼠标经过子元素时也会触发
- 鼠标经过子元素触发mouseout,mouseover事件的解决方案
- 判断鼠标移入移出元素时的方向
- mouseover、mouseout防止多次触发
- jquery的鼠标移入移出事件hover、mouseenter、mouseleave、mouseover、mouseout
- ScrollView里嵌套ListView,如何禁用ListView的滚动事件,或者触发ListView滚动时调用父元素ScrollView的滚动事件?
- javaScript , Jquery中如何获得当前鼠标悬浮的元素,如何获得当前鼠标的悬浮下的元素
- 如何禁用事件的浮升(div的子元素的点击事件会触发父元素的点击事件)
- jQuery事件函数-点击、双击、键盘按键、鼠标滑动、失去焦点、显示哪个 DOM 元素触发了事件/返回事件的类型。等
- 相对定位父子元素触发mouseover和mouseout事件实验
- IE中鼠标经过option触发mouseout的解决方法
- IE中鼠标经过option触发mouseout的解决方法
- 鼠标经过子元素触发mouseout,mouseover事件的解决方案
- 防止父元素事件被子元素触发
- 解决鼠标经过内部元素触发onmouseout事件的问题
- 如何判断鼠标进入元素的方向