时间:2021-05-25
我想实现的目标:当鼠标进入黑色框时,橙色框执行淡入动画;当黑色框范围移动的时候(即使经过粉色框,动画仍然不被触发);当鼠标移出的时候,橙色方块消失。
遇到的问题阐述:当鼠标移入黑色框的时候,橙色框执行淡入动画,但是当鼠标从黑色框经过粉色框的时候,橙色框就消失了,然后又执行一遍淡入动画。当鼠标从粉色框移出到黑色框的时候,橙色框的淡入动画又被执行。这不是我想要的。
初期代码:
<!DOCTYPE html><html><head><script src="jquery.js"></script> <meta charset="utf-8"> <title>mouseover mouseout</title> <style type="text/css" media="screen"> .parent{ width:200px; height:200px; background:black;}.child{ width:100px; height:100px; background:pink;}.a1{ width:40px; height:40px; background:orange; display:none;} </style></head><body><div class="parent"> <div class="child"></div> <div class="a1"></div></div><script>$('.parent').on('mouseover',function(e){ $('.a1').show(1000); }); $('.parent').on('mouseout',function(e){ $('.a1').css('display','none'); });</script></body></html>首先我们解释一下原因,为什么会出现这些问题。
当鼠标从黑色框移到粉色框的时候,此时黑色框的mouseout的被触发,又由于事件冒泡,黑色框的mouseover事件随即被触发,所以实际上,橙色框先消失,然后立即执行淡入动画。这也就是我们看到的过程。
当鼠标从粉色框移到黑色框的时候,此时黑色框的mouseout又被触发(因为不论鼠标穿过被选元素或其子元素,都触发 mouseover 事件),同时mouseover也被触发,所以又出现了再次执行淡入效果的过程。
方法一:用mouseleave/mouseout代替mouseover/mouseout【最佳方法】
先看一下mouseout&mouseover与mouseleave&mouseenter用法上的区别
mouseover与mouseenter
不论鼠标指针穿过被选元素或其子元素,都会触发 mouseover 事件。
只有在鼠标指针从元素外穿入被选元素(到元素内)时,才会触发 mouseenter 事件。
mouseout与mouseleave
不论鼠标指针离开被选元素还是任何子元素,都会触发 mouseout 事件。
只有在鼠标指针从元素内穿出被选元素(到元素外)时,才会触发 mouseleave 事件。
可以看一个简单的例子看看二者的区别
所以改进的代码可以为
<!DOCTYPE html><html><head><script src="jquery.js"></script> <meta charset="utf-8"> <title>mouseover mouseout</title> <style type="text/css" media="screen"> .parent{ width:200px; height:200px; background:black;}.child{ width:100px; height:100px; background:pink;}.a1{ width:40px; height:40px; background:orange; display:none;} </style></head><body><div class="parent"> <div class="child"></div> <div class="a1"></div></div><script>$('.parent').on('mouseenter',function(e){ $('.a1').show(1000); }); $('.parent').on('mouseleave',function(e){ $('.a1').css('display','none'); });</script></body></html>方法二:利用e.stopPropagation()阻止事件进一步传播
e.stopPropagation()会终止事件在传播过程的捕获、目标处理或起泡阶段进一步传播。调用该方法后,该节点上处理该事件的处理程序将被调用,事件不再被分派到其他节点。
<!DOCTYPE html><html><head><script src="jquery.js"></script> <meta charset="utf-8"> <title>mouseover mouseout</title> <style type="text/css" media="screen"> .parent{ width:200px; height:200px; background:black;}.child{ width:100px; height:100px; background:pink;}.a1{ width:40px; height:40px; background:orange; display:none;} </style></head><body><div class="parent"> <div class="child"></div> <div class="a1"></div></div> <script> $('.parent').on('mouseover',function(e){ $('.a1').show(1000); }); $('.parent').on('mouseout',function(e){ $('.a1').css('display','none'); }); $('.child').on('mouseover',function(e){ e.stopPropagation(); $('.a1').css('display','block'); //这是保证动画体的末状态不变 }); $('.child').on('mouseout',function(e){ e.stopPropagation(); //防止从粉色框移出到黑色框时再次触发其他事件 }) </script></body></html>拓展思考:
1.如果子元素过多怎么办,难道每个都要去绑定e.stopPropagation()?
用jquery的一个选择器.children(),比如$('.parent').children()。获得匹配元素集合中每个元素的子元素。
以上所述就是本文的全部内容了,希望大家能够喜欢。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
javascript的mouseover和mouseout事件,在绑定元素内部有子元素的情况下,经过绑定元素时会多次触发mouseover和mouseout事件
简单的鼠标移动事件:进入复制代码代码如下:mouseenter:不冒泡mouseover:冒泡不论鼠标指针穿过被选元素或其子元素,都会触发mouseover事件
1.不论鼠标指针离开被选元素还是任何子元素,都会触发mouseout事件。2.只有在鼠标指针离开被选元素时,才会触发mouseleave事件。复制代码代码如下:
mouseenter事件只会触发一次,触发对象是注册对象或者注册对象的子元素mouseover事件可以触发多次,触发对象是注册对象或者注册对象的子元素Docum
一、JS事件(一)JS事件分类1.鼠标事件:click/dbclick/mouseover/mouseout2.HTML事件:onload/onunload/o