在未嵌套子菜单的jquery导航菜单上实现setTimeout的问题



我有一个菜单列表,其中的子菜单没有嵌套用于样式设计。因此,我将使用mouseenter和mouseleave以及settimeout来实现悬停行为。

这是我的html:

<li class="dropdown"><a href="#">Link 1</a></li>
<div class="subnav">
<ul>
<li><a href="#">Link 1.1</a></li>
<li><a href="#">Link 1.2</a></li>
<li><a href="#">Link 1.3</a></li>  
<li><a href="#">Link 1.4</a></li>  
    </ul>
</div>
<li class="dropdown"><a href="#">Link 2</a></li>
<div class="subnav">
<ul>
<li><a href="#">Link 2.1</a></li>
<li><a href="#">Link 2.2</a></li>
<li><a href="#">Link 2.3</a></li>  
<li><a href="#">Link 2.4</a></li>  
    </ul>
</div> 
<li class="dropdown"><a href="#">Link 3</a></li>
<div class="subnav">
<ul>
<li><a href="#">Link 3.1</a></li>
<li><a href="#">Link 3.2</a></li>
<li><a href="#">Link 3.3</a></li>  
<li><a href="#">Link 3.4</a></li>  
    </ul>
</div> 
</ul>
</div><!-- End topNav -->

我的jquery:

$(document).ready(function(){  
var overSubmenuFlag = false;
var timeout;
var subnav;
var offset;
$("li.dropdown").mouseenter(function(){
    clearTimeout(timeout);
    $(".subnav").hide();
    $(this).children('a').addClass("active"); //Add active class to link element
    var subnav = $(this).next("div.subnav"); //find navigation box associated with this nav tab
    var offset = $(this).position(); //Position subnav relative to nav tab
    var leftpos = (offset.left + 15) + "px";
    var toppos = (offset.top + 36) + "px";
    subnav.css( { 
        position: 'absolute',
        left: leftpos, 
        top: toppos
    });
    subnav.show(); //Reveal subnav
}).mouseleave(function() {
    clearTimeout(timeout);
    var timeout = setTimeout(function() {
        if(!overSubmenuFlag) {
            var subnav = $("li.dropdown").next("div.subnav");
            subnav.hide();
            $("li.dropdown").children('a').removeClass("active");       
        }},100);        
});
$(".subnav").mouseenter(function(){
    clearTimeout(timeout);
    overSubmenuFlag = true;  
}).mouseleave(function(){   
    overSubmenuFlag = false; 
    $(".subnav").hide();
    $("li.dropdown").children('a').removeClass("active");       
}); 
});  

一切工作如预期,除了以下:当我鼠标离开一个导航标题和鼠标快速移动到另一个标题,与新标题相关的子菜单短暂出现,然后消失。(鼠标缓慢地在两个导航标题之间工作正常)。如何在进入新导航时正确地停止与setTimeout函数相关的所有操作(并关闭任何打开的子菜单)?头吗?非常感谢您的帮助!

这是你的问题吗?

}).mouseleave(function() {
    clearTimeout(timeout);
    var timeout = setTimeout(function() {
    ^^^

最新更新