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

时间:2011-12-11 19:30:08

标签: jquery menu settimeout mouseenter mouseleave

我有一个菜单列表,其子菜单没有嵌套用于样式目的。因此,我使用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功能关联的所有操作(并关闭所有打开的子菜单)。头?非常感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

这是你的问题吗?

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