javascript - 关于mouseenter的问题
问题描述
<head><style> .enter h2{border:1px solid;background: white;position: absolute;top: 200px; } .enter{ border:1px solid; background: #eee; width: 500px; height: 100px; }</style><script type='text/javascript' src='https://www.haobala.com/wenda/jquery/jquery-3.2.1.js'></script></head><body> <p>只有在鼠标指针穿过被选元素时,才会触发 mouseenter 事件。</p> <p class='enter'><h2 >被触发的 Mouseenter 事件:<span></span></h2> </p><script type='text/javascript'> x=0; y=0; $(document).ready(function(){ $('p.enter').mouseenter(function(){$('.enter span').text(y+=1); }); });</script></body>
当我用绝对定位把子元素移到下面,这时穿过子元素也会触发事件,这是怎么回事?
问题解答
回答1:absolute positioning 只是将元素抽离了 normal flow ,并没有改变 document tree 的结构,所以子元素依然算是在父元素里面。
解决方法可以是判断 event.target 是不是子元素,或者改为给两者绑定 mouseover 然后在子元素里 stopPropagation 。
回答2:根据https://www.w3.org/TR/uievent...
A user agent MUST dispatch this event when a pointing device is moved onto the boundaries of an element or one of its descendent elements. This event type is similar to mouseover, but differs in that it does not bubble, and MUST NOT be dispatched when the pointer device moves from an element onto the boundaries of one of its descendent elements.
翻译一下就是:
当指针一类的东西移到某个元素的边界上,或者它的某个后代元素的边界上,就必须触发mouseenter事件。而当指针从某个元素里,移到它的某个后代元素的边界上时,则不可触发mouseenter事件。
所以对于你的问题,回答就是,移到后代上也会触发mouseenter是人家规定了的
相关文章:
1. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????2. 在应用配置文件 app.php 中找不到’route_check_cache’配置项3. html按键开关如何提交我想需要的值到数据库4. css - width设置为100%之后列表无法居中5. ios - vue-cli开发项目webstrom会在stylus样式报错,飙红,请大神帮忙6. css3 - 怎么感觉用 rem 开发的不多啊7. python - 在pyqt中做微信的机器人,要在表格中显示微信好友的名字,却显示不出来,怎么解决?8. html5 - 用Egret写的小游戏,怎么分享到微信呢?9. javascript - 一个页面有四个图片,翻页的时候想固定住某个图片然后翻页,如何实现呢?10. objective-c - 自定义导航条为类似美团的搜索栏样式
