0

我有这个 HTML 代码:

<ul class="menu">
    <li>Home <span class="icon home"></span><div class="clear"></div></li>
    <li class="sub">Projects <span class="icon project"></span>
        <div class="clear"></div>
        <ul class="sub-menu">
            <li>Mfrsht.com</li>
            <li>Mawsuaty.com</li>
            <li>Dzlng.com</li>
            <li>Money(Ctrl)</li>
        </ul>
    </li>
    <li>Ideas <span class="icon idea"></span><div class="clear"></div></li>
    <li>Services <span class="icon service"></span><div class="clear"></div></li>
    <li>About us <span class="icon about"></span><div class="clear"></div></li>
    <li>Contact <span class="icon contact"></span><div class="clear"></div></li>
</ul>

和这个Javascript代码:

$(".menu > li").not(".menu > li.sub").css( {backgroundPosition: "0px 0px", height: "30px"} )
        .mouseover(function(){
            $(this).stop().animate({backgroundPosition:"(-167px 0px)", height: "36px"}, {duration:500})     
            })      
        .mouseout(function(){           
            $(this).stop().animate({backgroundPosition:"(0px 0px)", height: "30px"}, {duration:200, complete:function(){                $(this).css({backgroundPosition: "0px 0px"})            
            }})     
})

$(".menu > li.sub").css( {backgroundPosition: "0px 0px"} )
        .mouseover(function(){
            $(this).stop().animate({backgroundPosition:"(-167px 0px)"}, {duration:500}) 
            })      
        .mouseout(function(){           
            $(this).stop().animate({backgroundPosition:"(0px 0px)"}, {duration:200, complete:function(){                $(this).css({backgroundPosition: "0px 0px"})        
            }})     
})


$(".sub").hover(function() {
            $(this).animate({height: "150px"}, "slow", "", function () {
                $(this).children("ul.sub-menu").slideDown("slow");  
                });

    }, function() {
        $(this).animate({height: "30px"}, "slow");
        $(this).children("ul.sub-menu").slideUp("slow");    
        });

菜单运行良好,但有时我发现它滞后或有些迟到,所以我想改进它并让它变得更好。

注意:我正在使用背景位置插件。

演示

有什么建议么?还是您认为这样好,无需修改?

4

1 回答 1

4

需要考虑的几件事:

  1. 使用 mouseenter / mouseleave 而不是 mouseover / mouseout 在必要时实际触发处理程序(因为您不关心 muse 是否在菜单项区域内移动光标 - 只关心哪个项目光标进入和离开)。
  2. .stop(true)在事件处理程序中运行新动画之前使用。您已经在几个地方这样做了,但是您错过了一些地方(并且您没有清除动画队列)。尝试在整个菜单中随机移动光标,然后停下来观看混乱。事件处理程序在这里和那里触发,一些项目“悬停”,一些项目显示子菜单,只是稍后隐藏。通过传递true给停止函数,您告诉 jQuery 清除匹配对象的动画队列。您也可以考虑使用第二个参数 for .stop(),这将告诉jQuery 继续设置完成整个动画后对象的状态。但是,这(传递第二个参数)将取决于您如何调整代码,所以不要只这样做 - 检查这是否是一个理想的效果。
于 2012-08-26T18:37:41.643 回答