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 事件。