我有一个菜单列表,其中包含未嵌套用于样式目的的子菜单。因此,我将 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 函数相关的所有操作(并关闭任何打开的子菜单)。标题?非常感谢您的帮助!