鼠标的移入、移出事件

news/2025/1/6 5:40:33/

目录

一、mouseover和mouseenter

 二、mouseout和mouseleave

三、重点总结


在原生JS中鼠标移入移出事件有四个,分别为mouseover ,mouseout ,mouseenter,mouseleave,其中mouseovermouseenter为移入事件,mouseoutmouseleave为移出事件,那么问题来了,这每组事件之间究竟有什么区别呢?

一、mouseover和mouseenter

mouseover: 只要鼠标指针移入事件所绑定的元素或其子元素,都会触发该事件
mouseenter: 只有鼠标指针移入事件所绑定的元素时,才会触发该事件

 换句话说就是,如果一个元素没有子元素,那么该元素绑定mouseover或者mouseenter两种事件效果没有区别,鼠标每次移入元素时都只会触发一次事件;如果绑定了mouseover事件的元素存在子元素,那么,每次移入该元素时都会触发一次事件(包括从外部移入和从子元素移入),移入子元素时也会触发一次事件。

举个简单例子~

<div class="box over" onmouseover="over()"><span>over</span>
</div><div class="box enter" onmouseenter="enter()"><span>enter</span>
</div>
// mouseover事件
function over() {console.log('触发了mouseover事件!');
}// mouseenter事件
function enter() {console.log('触发了mouseenter事件!');
}

测试效果如下图所示:

 二、mouseout和mouseleave

这两者对比原理与mouseovermouseenter是一致的,如果上面理解了,那么这个也就理解了。

mouseout: 只要鼠标指针移出事件所绑定的元素或其子元素,都会触发该事件
mouseleave: 只有鼠标指针移出事件所绑定的元素时,才会触发该事件

换句话说就是,如果一个元素没有子元素,那么该元素绑定mouseout或者mouseleave两种事件效果没有区别,鼠标每次移出元素时都只会触发一次事件;如果绑定了mouseout事件的元素存在子元素,那么,每次移出该元素时都会触发一次事件(包括移出至外部移出至子元素),从子元素移出时也会触发一次事件。

举个简单例子~

<div class="box out" onmouseout="out()"><span>out</span>
</div><div class="box leave" onmouseleave="leave()"><span>leave</span>
</div>
// mouseout事件
function out() {console.log('触发了mouseout事件!');
}// mouseleave事件
function leave() {console.log('触发了mouseleave事件!');
}

测试效果如下图所示:

通过以上图文详解,相信你已经能清楚这些事件之间的区别了吧!如果你看完还是有疑问的话,请戳→此处←亲身体验吧~

三、重点总结

① 只要鼠标指针移入(或移出)事件所绑定的元素或其子元素,都会触发mouseover(或mouseout)事件
② 只有鼠标指针移入(或移出)事件所绑定的元素时,才会触发mouseenter(或mouseleave)事件


http://www.ppmy.cn/news/455898.html

相关文章

k8s 的 Deployment控制器

1. RS与RC与Deployment关联 RC&#xff08;Replication Controller&#xff09;主要作用就是用来确保容器应用的副本数始终保持在用户定义的副本数。即如果有容器异常退出&#xff0c;会自动创建新的pod来替代&#xff1b;而如果异常多出来的容器也会自动回收。K8S官方建议使用…

公司电脑监控软件能看到哪些内容

想要知道公司电脑监控软件可以监控哪些内容首先要了解公司电脑监控软件都有哪些功能&#xff0c;下面就以易掌电脑监控为例讲解它所能监控的内容。 1、电脑屏幕实时监控 易掌电脑监控软件可以让管理者可实时查看当前被管控电脑的画面情况及被控端的摄像头的画面&#xff0c;并且…

如何监控自己手机上的网络访问

https://blog.csdn.net/forlong401/article/details/23538951 用Fiddler 加代理是最靠谱的 用adb也可以。https://blog.csdn.net/sunjing_/article/details/51878859

什么是云端远程监控?随时随地查看电脑监控画面。

什么是云端监控&#xff1f; 顾名思义&#xff0c;就是通过远程连接的方式来监控电脑&#xff0c;被监控的电脑日志可以上传到云端服务器&#xff0c;而且用户只需在网页上登录就可以查看监控记录。这种监控方式&#xff0c;不受网络环境&#xff0c;地域的限制。只要客户端电脑…

在外远程查看家里内网监控

现代生活节奏紧张&#xff0c;巨大的压力压得我们喘不过气来&#xff0c;因此很多人选择在家里养一只陪伴我们的宠物&#xff0c;用以舒缓紧张的情绪和繁重的压力。但养了这些小家伙后&#xff0c;不在家时又总想随时看看家里小可爱们的情况&#xff0c;这时我们就能利用cpolar…

UnityVR-项目的管理阶层

目录 概述 项目的总体架构 单例基类 继承MonoBehaviour的单例基类 概述 一个具备一定规模的项目&#xff0c;一般都需要由不同人员合作完成&#xff0c;每个人的想法风格不相同&#xff0c;如果一开始没有定下基本的框架&#xff0c;会让实现时混乱不堪&#xff0c;而且无法…

获知局域网内他人的上网数据和行为

作者&#xff1a;邹祁峰 邮箱&#xff1a;Qifeng.zou.jobhotmail.com 博客&#xff1a;http://blog.csdn.net/qifengzou 日期&#xff1a;2015.12.16 转载请注明来自"祁峰"的CSDN博客 由于互联网的快速发展&#xff0c;人们的生活、休闲、工作已经越来越离不开网络。…

web 页面接入局域网监控视频

1. 网络摄像头 / NVR, 需要知道其IP和登录账号密码, 大部分支持使用工具扫描和重置密码; 2. 推流设备; 3. 摄像头和推流器接入同个局域网; 4. 使用VLC播放器播放验证 摄像头或录像机输出的 rtsp 视频源, 海康常见地址格式见文末; 5. 使用 推流器的局域网扫描工具 找到其 i…