JavaScript中onmouseenter、onmouseleave和onmouseover、onmouseout的区别

鼠标事件在工作中经常会用到,对于刚入门前端的学童有些人对onmouseenter、onmouseleave和onmouseover、onmouseout的使用会有疑惑,两者有什么区别呢,我们通过下面两个实例来分析。

 

实例1:只有一个元素,没有子元素

实例2:如果鼠标从上到下经过全部dom元素

结果统计:
实例1中【onmouseenter、onmouseleave】、【onmouseover、onmouseout】事件各触发1次事件处理程序。
实例2中【onmouseenter、onmouseleave】事件触发1次事件处理程序,【onmouseover、onmouseout】事件会触发10次事件处理程序。

得出结论:
如果父元素中没有子元素,【onmouseenter、onmouseleave】事件和【onmouseover、onmouseout】事件都只会触发一次事件处理程序;
如果父元素中含有子元素 【onmouseenter、onmouseleave】事件仍旧只会触发一次对应的事件处理程序,【onmouseover、onmouseout】事件会触发多次(触发次数和鼠标经过的子元素个数有关)事件处理程序。

总结:

onmouseover、onmouseout:鼠标经过时自身会触发事件,经过其子元素时也会触发该事件;

onmouseenter、onmouseleave:鼠标经过时自身触发事件,经过其子元素时不会触发该事件;

注意:这四个事件要两两配对使用,不能混合使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值