仅当尚未触发另一个 mouseover 事件时,如何为 jquery mouseout 事件创建异常?

发布于 2024-11-30 09:59:03 字数 994 浏览 5 评论 0原文

基本上,我的客户希望当鼠标悬停在图像上时显示隐藏的导航。我已经解决了当您将鼠标悬停在导航上时导航不隐藏,然后当您离开导航时隐藏的问题。我遇到了两个问题,我尝试了各种不同的组合,我认为这些组合会起作用,但当然没有。这两个问题是:

  1. 当您将鼠标悬停在图像上而没有将鼠标悬停在导航上时,导航需要隐藏,从现在开始,它会保持打开状态,直到您再次将鼠标悬停在图像上或鼠标离开导航。

  2. 第二个问题是,当您将鼠标离开导航直接将鼠标悬停在图像上时,它会循环该功能并隐藏导航,然后再次打开导航,我尝试将slideToggle更改为显示,但这会导致一大堆其他问题。< /p>

现在代码的行为与我想要的非常接近,并且可以被认为是可以接受的,但我很想知道如何解决上述问题。我想过使用hoverIntent插件来感知鼠标移动,并仅在鼠标减慢时触发功能,但无法使其正常工作。显然,我是 javascript 和 jquery 方面的新手,所以请原谅我,但我真的很感激任何帮助。

这是我的代码

$(document).ready(function(){

$(".nav-body").hide();

$(".nav-head").mouseover(function(){
$(this).next(".nav-body").slideToggle(600);
$(".nav-body").mouseleave(function(){
$(this).hide(700);
});
});

});

这是我的 html:

<p class="nav-head"><img src="/images/face-btn.jpg" /></p> 
<div class="nav-body"> 
<ul><?php wp_list_pages('title_li=&child_of=12&depth=1'); ?></ul> 
</div>

Basically my client wants hidden navigation to appear when mouseover an image. I've solved the problem of the navigation not hiding when you mouseover the navigation and then hiding when you leave the navigation. There are two problems I'm running into and I've tried a variety of different combinations that I thought would work, but of course didn't. The two problems are:

  1. When you mouseout the image without mouseover the navigation then the navigation needs to hide, as of right now it stays open until you either mouseover the image again or mouseleave the navigation.

  2. Second problem is when you mouseleave the navigation directly to mouseover the image it loops the function and hides the nav then opens the nav again, I've tried changing slideToggle to show, but that causes a whole bunch of other issues.

Right now the code is behaving as close to how I want it and could be considered acceptable, but I'd love to know how to solve the problems above. I thought about using the hoverIntent plugin to sense the mouse movements and only trigger the functions once the mouse has slowed, but couldn't get it working properly. Clearly, I am a novice when it comes to javascript and jquery so please forgive me, but I'd really appreciate any help.

Here is my code

$(document).ready(function(){

$(".nav-body").hide();

$(".nav-head").mouseover(function(){
$(this).next(".nav-body").slideToggle(600);
$(".nav-body").mouseleave(function(){
$(this).hide(700);
});
});

});

Here is my html:

<p class="nav-head"><img src="/images/face-btn.jpg" /></p> 
<div class="nav-body"> 
<ul><?php wp_list_pages('title_li=&child_of=12&depth=1'); ?></ul> 
</div>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

2024-12-07 09:59:03

标记更改

<div class="nav-container">
    <p class="nav-head"></p>
    <div class="nav-body"></div>
</div>

Javascript

var eventHandler;

eventHandler = function(){$(".nav-head").one("mouseover",function(){
   $(this).next(".nav-body").slideToggle(600);
    $(".nav-container").one("mouseleave", function(){
        $(this).find(".nav-body").hide(700, eventHandler);
    });
});};

eventHandler();

第一个更改是从 mouseleave 更改为 mouseout。在导航内部,可能有覆盖实际导航主体的后代元素。使用鼠标离开时,处理程序仅在鼠标离开绑定元素时触发。如果越过下降元素,则视为离开。 Mouseout 仅在超出绑定对象的边界时触发。

我做的第二件事是为处理程序绑定操作分配一个委托,以便我可以将其用作 hide() 的回调函数。这样,在隐藏完全完成之前,事件处理程序不会恢复到导航头。

最后一个是将 mouseout 处理程序分配给包含的 div。这样,只要它离开导航头(或导航主体),因为它被包含,主体就会隐藏。

Markup change

<div class="nav-container">
    <p class="nav-head"></p>
    <div class="nav-body"></div>
</div>

Javascript

var eventHandler;

eventHandler = function(){$(".nav-head").one("mouseover",function(){
   $(this).next(".nav-body").slideToggle(600);
    $(".nav-container").one("mouseleave", function(){
        $(this).find(".nav-body").hide(700, eventHandler);
    });
});};

eventHandler();

The first change is from mouseleave to mouseout. Inside the navigation, there are likely to be descendent elements that cover the actual nav-body. With mouse leave, the handler only triggers when the mouse leaves the bound element. If it goes over descend it elements, it is considered leaving. Mouseout only triggers if it is outside the bounds of the bound object.

The second thing I did was assign a delegate to the handler binding operation so that I could use it as a callback function for hide(). This way, the event handler won't be restored to the nav-head until the hide is completely done.

The last was to assign the mouseout handler to the containing div. This way, the so long as it leaves the nav-head (or the nav-body) since its contained, the body will hide.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文