首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何更好地控制这个jQuery UI脚本,它在mouseover/mouseout事件上向div添加一个覆盖?

如何更好地控制这个jQuery UI脚本,它在mouseover/mouseout事件上向div添加一个覆盖?
EN

Stack Overflow用户
提问于 2020-01-27 10:20:02
回答 1查看 22关注 0票数 0

我正在为一个网站建立一个主页,它包含在<div>元素中的许多促销链接。

为了更有趣,我设计了一个覆盖<img>,当用户将光标悬停在相应的宣传片上时,它会出现在<div>上,然后当光标被移除时消失。我使用jQuery UI .toggle()效果对其进行上下动画化,如下所示:

代码语言:javascript
运行
复制
$("#hp-promo-1").on("mouseover", function() {
  $("#promo-1-overlay").toggle("slide", {direction: "right"})
})

$("#hp-promo-1").on("mouseout", function() {
  $("#promo-1-overlay").toggle("slide", {direction: "right"})
})

虽然这是有效的,因为它动画覆盖和关闭,我有问题,行使任何形式的控制它。有时覆盖会反复滑动,甚至在mouseout事件之后也是如此。

我可以向这段代码介绍什么,以确保覆盖层只在一次上滑动,然后保持在mouseover上的位置,然后滑动一次,然后隐藏在mouseout?上。

EN

回答 1

Stack Overflow用户

发布于 2020-01-27 15:12:37

我用mouseovermouseout代替mouseentermouseleave来解决这个问题。

这个问题是由光标通过<div>中包含的元素引起的(例如文本),这触发了mouseout事件,但是mouseleave忽略了<div>中包含的元素,只有当用户的游标离开div本身时才会触发。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59929114

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档