4

好的,假设我有一个在嵌套 div 中构建的导航系统,当我在菜单 div 上执行鼠标悬停并隐藏子菜单 div(和 sub-子菜单 div)在鼠标悬停时,或者更准确地说,当我将鼠标悬停在不同的菜单 div 上时。

最好的方法是什么?

到目前为止,这就是我所拥有的:

<script type="text/javascript">

$('.menu').mouseover(function(){ 
      $(this).children(".submenu").each(function(i){
        $(this).delay(1000).slideDown("slow");

$(this).mouseover(function(i){ 
$(this).children(".sub_submenu").each(function(i){
        $(this).delay(1000).slideDown("slow");

});
});
</script>


<div id="" class="menu">
menu1
<div id="" class="submenu">
submenu11
<div id="" class="sous_sousmenu">
sub_submenu111
</div>
<div id="" class="sub_submenu">
sub_submenu112
</div>
</div>
<div id="" class="submenu">
submenu12
</div>
</div>
<div id="" class="menu">
<a href="#">menu2</a>
<div id="" class="submenu">
sousmenu21
</div>
<div id="" class="submenu">
submenu22
<div id="" class="sub_submenu">
sub_submenu21
</div>
</div>
</div>

现在,当我将鼠标悬停在正确的菜单 div 上时,一切正常(显示子菜单和子子菜单)。现在,当我对不同的 .menu div 进行鼠标悬停时,我应该在哪里/何时/如何告诉脚本对所有 .submenu 和 .sub_submenu 进行 slideUp?

谢谢

4

1 回答 1

3

尝试这样的事情(演示):

HTML

<div id="" class="menu">
    menu1
    <div id="" class="submenu">
        submenu11
        <div id="" class="submenu">
            sub_submenu111
        </div>
        <div id="" class="submenu">
            sub_submenu112
        </div>
    </div>
    <div id="" class="submenu">
        submenu12
    </div>
</div>
<div id="" class="menu">
    <a href="#">menu2</a>
    <div id="" class="submenu">
        sousmenu21
    </div>
    <div id="" class="submenu">
        submenu22
        <div id="" class="submenu">
            sub_submenu21
        </div>
    </div>
</div>

脚本

$('.menu, .submenu').hover(function(){
    $(this).children('.submenu').stop(true, true).slideDown("slow");
}, function(){
    $(this).children('.submenu').stop(true, true).delay(1000).slideUp("slow");
});
于 2010-10-02T21:07:05.440 回答