スタイリング目的でネストされていないサブメニューを含むメニュー リストがあります。したがって、ホバリング動作には、settimeout と一緒に mouseenter と mouseleave を使用しています。
これが私の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");
});
});
次の点を除いて、すべてが意図したとおりに機能します。1 つのナビゲーション ヘッダーをマウスアウトし、別のヘッダーにすばやくマウスオーバーすると、新しいヘッダーに関連付けられたサブメニューが一時的に表示されてから消えます。(2 つのナビゲーション ヘッダー間でゆっくりとマウスを動かすと、適切に動作します)。新しいナビゲーションに入ったときに setTimeout 関数に関連付けられているすべてのアクションを適切に停止する (および開いているサブメニューを閉じる) にはどうすればよいですか? ヘッダ?助けてくれてありがとう!