botões animados jQuery que simplesmente não se comportam
-
28-09-2019 - |
Pergunta
Ok, eu tenho uma lista embutida de botões.
<ul id="nav">
<li class="home"><a href="#">Menu Item</a></li>
<li class="contact"><a href="#">Menu Item</a></li>
<li class="about"><a href="#">Menu Item</a></li>
</ul>
.home{
position:absolute;
bottom:0;
background-image:url(../img/menu/single_line.png);
background-repeat:no-repeat;
height:34px;
width:134px;
}
.home_hover{
position:absolute;
bottom:0;
background-image:url(../img/menu/single_line_over.png);
background-repeat:no-repeat;
height:70px;
width:134px;
}
$(document).ready(function(){
$("#nav .home").mouseover(function(){
$(this).toggleClass("home_hover").slideToggle("slow");
return false;
}).mouseout(function(){
$(this).toggleClass("home_hover").slideToggle("slow");
return false;
});
});
Cada item de menu possui uma imagem de fundo e, quando o mouse, a imagem de fundo é substituída por uma imagem mais alta. Por fim, estou tentando criar um menu simples, onde no mouseOr, o item do menu parece deslizar para cima. Mas, na realidade, o jQuery pode animar o toggleClass com o slidetoggle. O problema é que esse código atual não se comporta corretamente.
Ele pula para cima e para baixo, porque o texto está se movendo. Eu sou muito novo no JQuery, então qualquer ajuda é muito apreciada. Eu também carreguei isso em http://gasworks.ravenenainteractive.com/result/
obrigado
Solução
Tente isso (demonstração):
CSS:
#header{
height:100px;
}
#nav{
height:34px;
position:relative;
}
.home{
position:absolute;
bottom:0;
background-image:url(http://gasworks.ravennainteractive.com/result/img/menu/single_line.png);
background-repeat:no-repeat;
height:34px;
width:134px;
}
.home_hover{
background-image:url(http://gasworks.ravennainteractive.com/result/img/menu/single_line_over.png);
}
Roteiro
$(document).ready(function(){
$("#nav li").mouseover(function(){
$(this).addClass('home_hover').stop().animate({ height: '70px'},'slow');
}).mouseout(function(){
$(this).stop().animate({ height: '34px'},'slow', function(){
$(this).removeClass('home_hover');
})
});
});
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow