mouseover和mouseenter事件使用函数的区别

今天做一个小案例,是一个分享的滑动效果。鼠标移入则滑出隐藏的内容。
一开始非常不理解为何老师用jquery的mouseenter事件方法监听而不用mouseover。
这里就要谈谈事件冒泡机制了,简单的理解就是内层dom文档监听或发生的事件会向上层传递。当执行到有事件监听的元素时执行对应的监听函数直到文档结束为止。
那么困惑我的就是这个内层元素没有设置监听函数当发生相应的事件时它还会不会向上层传递这个事件发生的信息呢?
所以我就要设计一个实验来证明它!如果验证了就说明了为何当用mouseover事件监听方法时会出现多次执行的情况。
验证思路如下:
在一个div里添加一个按钮不设置任何的事件监听函数。然后给这个父层的div设置宽高样式,和一个click事件监听函数。当点击这个button时看父层div是否执行了相应的事件函数.
验证代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>jq14 动画阶段练习2</title>
	<style type="text/css">
		#wrap{
			width: 300px;
			height: 300px;
			background:red;
			text-align: center;
			line-height: 300px;
		}
	</style>
</head>
<body>
<div id="wrap">
	<input type="button" value="点击">
</div>
	<script>
		var d=document.getElementById('wrap')
		d.onclick=function(){
			alert('asd')
		}
	</script>
</body>
</html>

执行结果如下
在这里插入图片描述这样就知道了为何当有子元素时我们要使用mouseenter来监听。
因为当用mouseover时子元素即使没事设置对应的事件监听也会产生事件过程并产生冒泡向上传递。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智者_若愚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值