jQuery 中的 mouseenter 和 mouseover 的区别?

2016-10-12 21:19:20 +08:00
 sunshineHu

什么是穿透???
首先来说说 mouseenter 和 mouseover 的相同点吧,二者都是鼠标划入事件,当鼠标划入指定的元素时就会触发事件。在所选元素没有子元素等嵌套元素的话,我觉得用 mouseenter 和 mouseover 都一样。
但是,不同的是:如果所选元素有嵌套的话, mouseover 可能就会被触发多次,而 mouseenter 则只会执行一次。因为只有在鼠标指针穿透该元素时才会触发 mouseenter 事件,而鼠标指针穿过任何子元素,都会触发 mouseover 事件。
For example :

<style>
*{margin:0;padding:0;}
#outer{width:200px;height:200px;background:red;}
#inner{width:100px;height:100px;backgroud:blue;}
</style>
<script>
$("#outer").mouseenter(function(){
console.log(1);//控制台只会显示一次
})

$("#outer").mouseover(function(){
console.log(1);//鼠标移入显示一次,鼠标在子元素划过也会显示。
})
</script>
那么,问题来了,穿透!到底是什么意思???表示不太懂,求大神详解???
2942 次点击
所在节点    程序员
5 条回复
sunshineHu
2016-10-12 21:19:48 +08:00
<div id="outer">
<div id="inner"></div>
</div>
这是布局,不知道为什么显示不出来
sunshineHu
2016-10-12 21:20:12 +08:00
大神们帮我看看
iamzuoxinyu
2016-10-12 21:48:26 +08:00
搜一下“ js 冒泡机制”。
noe132
2016-10-12 23:01:37 +08:00
mouseenter 是定制版的 mouseover 。

子元素的 mouseover 会冒泡到父级元素和祖先元素,通常 情况下我们并不像捕捉到子元素的 mouseover 事件
所以有了 mouseenter 这个事件。只有触发元素和事件绑定的元素是同一个元素的时候, mouseenter 才会触发。
https://developer.mozilla.org/en-US/docs/Web/Events/mouseenter
linyongqianglal
2016-10-13 13:53:57 +08:00
参考事件的冒泡和捕获

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/312344

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX