我的切换正在发生,但它也会应用于第二个嵌套级别。
在加载时,我只想要Parent One和Parent Two,首先嵌套UL不显示。第二个嵌套的UL将在此LI内保持打开状态。
当我点击Parent One或Parent Two时,第一个嵌套的ul应该打开/关闭。第二个嵌套的UL应始终在此LI内保持打开状态。
<div class="navColumn">
<ul class="ltColmenu">
<li><a href="">No Child 1</a></li>
<li><a href="">No Child 2</a></li>
<li><a href="">No Child 3</a></li>
<li><a href="#" class="headNavItem headNavItemClose">Parent One</a>
<ul>
<li><a href="">Item 1</a></li>
<li><a href="">Item 2</a></li>
<li><a href="">Item 3</a></li>
<li><a href="" class="headNavItem">Item 4</a>
<ul>
<li><a href="">Item 1 -1</a></li>
<li><a href="">Item 1 -2</a></li>
<li><a href="">Item 1 -3</a></li>
<li><a href="">Item 1 -4</a></li>
</ul>
</li>
</ul>
</li>
<li><a href="">No Child 4</a></li>
<li><a href="">No Child 5</a></li>
<li><a href="#" class="headNavItem headNavItemClose">Parent Two</a>
<ul>
<li><a href="">Item 5</a></li>
<li><a href="">Item 6</a></li>
<li><a href="">Item 7</a></li>
<li><a href="" class="headNavItem">Item 8</a>
<ul>
<li><a href="">Item 2 -1</a></li>
<li><a href="">Item 2 -2</a></li>
<li><a href="">Item 2 -3</a></li>
<li><a href="">Item 2 -4</a></li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
我有以下jquery,选择器也在拾取第4项和第8项。我不想要这种行为。我只希望选择器选择Parent One和Parent Two。我该如何解决这个问题?
$(document).ready(function () {
//onload hide first level nested items, all other levels will remain open inside top LI
$("ul.ltColmenu > li ul").slideToggle("fast");
//click on first level LIs, as first level only toggles. all other levels will remain open inside top LI
$("ul.ltColmenu > li a.headNavItem").click(function(){
if ($(this).next("ul").is(':visible')) {
$(this).removeClass("headNavItemOpen").removeClass("headNavItemClose").addClass("headNavItemClose");
}
else{
$(this).removeClass("headNavItemOpen").removeClass("headNavItemClose").addClass("headNavItemOpen");
}
$(this).next("ul").slideToggle("slow");
return false;
});
});
答案 0 :(得分:0)
这对我有用......
$(document).ready(function () {
//onload hide first level nested items, all other levels will remain open inside top LI
$("ul.ltColmenu > li > ul").slideToggle("fast");
//click on first level LIs, as first level only toggles. all other levels will remain open inside top LI
$("ul.ltColmenu > li > a.headNavItem").click(function(){
if ($(this).next("ul").is(':visible')) {
$(this).removeClass("headNavItemOpen").removeClass("headNavItemClose").addClass("headNavItemClose");
}
else{
$(this).removeClass("headNavItemOpen").removeClass("headNavItemClose").addClass("headNavItemOpen");
}
$(this).next("ul").slideToggle("slow");
return false;
});
});