程序员求职经验分享与学习资料整理平台

网站首页 > 文章精选 正文

笔记篇——关于js的鼠标移入移出 js鼠标移动到指定位置

balukai 2024-12-30 02:03:19 文章精选 15 ℃
document.getElementById("selectModal").onmouseenter = function() {
    console.log('鼠标移入')
}
document.getElementById("selectModal").onmouseover = function() {
     console.log('鼠标移入')
 }
document.getElementById("selectModal").onmouseleave = function() {
  console.log('鼠标移出')
}
document.getElementById("selectModal").onmouseout = function() {
     console.log('鼠标移入')
 }

关于鼠标移出效果的坑

问题:当div里面嵌套子级时,外层div监听鼠标移入和移出时间就会不停地触发。

div是多层嵌套,有时就会出现你的鼠标没有移出外层的div,只是移入了内层的div,也会触发鼠标的移出事件。

解决办法:

使用mouseenter来代替mouseover;使用mouseleave来代替mouseout。

他们的区别是:

不论鼠标指针穿过被选元素或其子元素,都会触发 mouseover 事件。

只有在鼠标指针穿过被选元素时,才会触发 mouseenter 事件。

不论鼠标指针离开被选元素还是任何子元素,都会触发 mouseout 事件。

只有在鼠标指针离开被选元素时,才会触发 mouseleave 事件。

最近发表
标签列表