【问题标题】:Simple hover controls简单的悬停控件
【发布时间】:2018-07-06 05:31:19
【问题描述】:

所以我有几个方块,当我将鼠标悬停在一个方块上时,我希望显示一个菜单。然后,当我悬停时,我希望它消失。简单吧?

所以问题是当我将鼠标快速移到它们上方时,它们中的一些会保持...隐藏。我可以从squares 辞职,变得透明,但我的mouseout 事件也没有被触发。因为我的鼠标离我很远,我的黑色菜单仍然在一个正方形的顶部!

所以淡出粉红色方块更能说明问题。我最烦恼的是黑色方块不消失。

$(document).ready(function() {
  $('.square').mouseenter(faceon);
  $('#hover_controls').mouseleave(faceout);
});

function faceon() {
  $(this).stop().clearQueue().fadeTo("slow", 0.15);
  $('#hover_controls').stop().clearQueue().css({
    top: $(this).offset().top + "px",
    left: $(this).offset().left + "px",
    display: 'block'
  }).fadeTo("fast", 1);
}

function faceout(event) {
  var e = event.toElement || event.relatedTarget;
  if (e.parentNode == this || e == this) {
    return;
  }
  $('.square').stop().clearQueue().fadeTo("slow", 1);
  $('#hover_controls').stop().clearQueue().fadeTo("fast", 0, function() {
    $(this).hide();
  });
}
.square {
  height: 72px;
  width: 72px;
  background: pink;
  margin: 5px;
  display: inline-block;
}

#hover_controls {
  display: none;
  height: 62px;
  width: 62px;
  opacity: 0;
  padding: 5px;
  position: fixed;
  background: #000;
  border-radius: 10px;
  z-index: 2;
  cursor: pointer;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id='hover_controls'>
  <a href='#' onclick='alert("aaa");'>a</a>
  <a href='#' onclick='alert("bbbb");'>b</a>
</div>

<div class="list">
  <div class="square"></div>
  <div class="square"></div>
  <div class="square"></div>
</div>

有什么想法吗?

【问题讨论】:

  • 我希望使用mouseentermouseleave 而不是mouseovermouseout 可以改善结果。
  • 使用 mouseentermouseleave 似乎为我解决了这个问题。
  • 把mouseout函数作为mousein one的回调
  • mouseout 并不是那么可靠。很长一段时间以来一直很麻烦。 stackoverflow.com/questions/7448468/…
  • FWIW { 错误:“消息”:“TypeError:e 为空”,运行时。

标签: javascript jquery onmouseover onmouseout


【解决方案1】:

mouseovermouseout 分别替换为mouseentermouseleave。我希望这会有所帮助。

【讨论】:

  • 更改为mouseentermouseleave,仍然发生。
【解决方案2】:

更改事件处理程序,在e 为空的情况下,如果鼠标快速移出,则使用条件e 修复问题。

这里的复杂之处在于 mouseenter/mouseleave 和动画 - 请注意,这些事件位于不同的元素上,您可以在事件触发时显示/隐藏其中一个元素。因此,mouseleave 事件可能不会一直正确触发,因为它被挂钩的元素在“快速鼠标”动作行为中不可见。

$(document).ready(function() {
  $('.square').on("mouseenter", faceon);
  $('#hover_controls').on("mouseleave", faceout);
});

function faceon() {
  $(this).stop().clearQueue().fadeTo("slow", 0.15);
  $('#hover_controls').stop().clearQueue().css({
    top: $(this).offset().top + "px",
    left: $(this).offset().left + "px",
    display: 'block'
  }).fadeTo("fast", 1);
}

function faceout(event) {
  var e = event.toElement || event.relatedTarget;
  if (e && (e.parentNode == this || e == this)) {
    return;
  }
  $('.square').stop().clearQueue().fadeTo("slow", 1);
  $('#hover_controls').stop().clearQueue().fadeTo("fast", 0, function() {
    $(this).hide();
  });
}
.square {
  height: 72px;
  width: 72px;
  background: pink;
  margin: 5px;
  display: inline-block;
}

#hover_controls {
  display: none;
  height: 62px;
  width: 62px;
  opacity: 0;
  padding: 5px;
  position: fixed;
  background: #000;
  border-radius: 10px;
  z-index: 2;
  cursor: pointer;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id='hover_controls'>
  <a href='#' onclick='alert("aaa");'>a</a>
  <a href='#' onclick='alert("bbbb");'>b</a>
</div>

<div class="list">
  <div class="square"></div>
  <div class="square"></div>
  <div class="square"></div>
</div>

【讨论】:

  • 似乎还是会发生:imgur.com/a/MX982 - 也许我应该从头开始,以其他方式?如果我将鼠标从一侧飞到另一侧,它就会卡住。我知道人们会这样做。它修复了错误。
  • 添加了关于此的注释。我鼓励您搜索,因为关于“mouseenter mouseleave site:stackoverflow.com”的谷歌还有其他问题
猜你喜欢
  • 2014-02-12
  • 1970-01-01
  • 2010-12-03
  • 2013-12-03
  • 1970-01-01
  • 2012-06-25
  • 1970-01-01
  • 2016-02-16
  • 1970-01-01
相关资源
最近更新 更多