[Tutorial] Efeito para menu (jQuery)

Ver o tópico anterior Ver o tópico seguinte Ir em baixo

[Tutorial] Efeito para menu (jQuery)

Mensagem por Nerdzinhu em Sex Fev 03, 2012 4:15 pm

:: Visualize o efeito




Código CSS
Código:
<style type="text/css">
   h2   {clear:both;padding-top:20px;}
   ul {list-style:none;margin:0;padding:0;}
   li {float:left;width:100px;margin:0;padding:0;text-align:center;}
   li a {display:block;padding:5px 10px;height:100%;color:#FFF;text-decoration:none;border-right:1px solid #FFF;}
   li a {background:url(bg2.jpg) repeat 0 0;}
   li a:hover, li a:focus, li a:active {background-position:-150px 0;}
   #a a {background:url(bg.jpg) repeat -20px 35px;}
   #b a {background:url(bg2.jpg) repeat 0 0;}
   #c a {background:url(bg3.jpg) repeat 0 0;}
   #d a {background:url(bg4.jpg) repeat 0 0;}
</style>


#a a {background:url(bg.jpg) repeat -20px 35px;} // Declara o background ,repetindo o background ,na posição -20 , 35.
#b a {background:url(bg2.jpg) repeat 0 0;} // Declara o bg tambem ,só que repetindo , e na posição zerada
#c a {background:url(bg3.jpg) repeat 0 0;} // O mesmo da de cima
#d a {background:url(bg4.jpg) repeat 0 0;} // idem



li a {background:url(bg2.jpg) repeat 0 0;} // declara que quando passar o mouse em cima , vá para o background 2 , com a posição zerada.




background:url(bg2.jpg) repeat 0 0;
CIMA/BAIXO
ESQUERDA/DIREITA




Código:
<script type="text/javascript" src="jquery-1.2.6.min.js"></script>
<script type="text/javascript" src="jquery.bgpos.js"></script>


Chame esses arquivos de Javascript para sua pagina





Código jQuery para o funcionamento do efeito.
Irei explicar apenas 1 , que os demais da para ter noção de como os outros funcionam.
Código:
<script type="text/javascript">

$(function(){
   $('#a a')
      .css( {backgroundPosition: "-20px 35px"} )
      .mouseover(function(){
         $(this).stop().animate({backgroundPosition:"(-20px 94px)"}, {duration:500})
      })
      .mouseout(function(){
         $(this).stop().animate({backgroundPosition:"(40px 35px)"}, {duration:200, complete:function(){
            $(this).css({backgroundPosition: "-20px 35px"})
         }})
      })
   $('#b a')
      .css( {backgroundPosition: "0 0"} )
      .mouseover(function(){
         $(this).stop().animate({backgroundPosition:"(-150px 0)"}, {duration:500})
      })
      .mouseout(function(){
         $(this).stop().animate({backgroundPosition:"(-300px 0)"}, {duration:200, complete:function(){
            $(this).css({backgroundPosition: "0 0"})
         }})
      })
   $('#c a')
      .css( {backgroundPosition: "0 0"} )
      .mouseover(function(){
         $(this).stop().animate({backgroundPosition:"(0 -250px)"}, {duration:500})
      })
      .mouseout(function(){
         $(this).stop().animate({backgroundPosition:"(0 0)"}, {duration:500})
      })
   $('#d a')
      .css( {backgroundPosition: "0 0"} )
      .mouseover(function(){
         $(this).stop().animate({backgroundPosition:"(0 -250px)"}, {duration:500})
      })
      .mouseout(function(){
         $(this).stop().animate({backgroundPosition:"(0 0)"}, {duration:500})
      })
});
</script>

</head>
<body>
<h1>jQuery Background Position</h1>
<h2>Example 0: No Script</h2>
   <ul id="noscript">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
   </ul>

<h2>Example A: Top down</h2>
   <ul id="a">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
   </ul>

<h2>Example B: Right left</h2>
   <ul id="b">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
   </ul>
<h2>Example C: Fade 1-colour</h2>
   <ul id="c">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
   </ul>
<h2>Example D: Fade 2-colour</h2>
   <ul id="d">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
   </ul>


$('#a a') Chama ,e declara qual id irá chamar para definir o efeito.
.css( {backgroundPosition: "-20px 35px"} ) Define posição default
.mouseover(function(){ Função vai funcionar quando passar o mouse
$(this).stop().animate({backgroundPosition:"(-20px 94px)"}, {duration:500}) O efeito vai para quando o background se mover.
(Posição de onde a segunda imagem contem o efeito.)
})
.mouseout(function(){
$(this).stop().animate({backgroundPosition:"(40px 35px)"}, {duration:200, complete:function(){
$(this).css({backgroundPosition: "-20px 35px"})


Todas essas linhas são a mesma coisa , só que o contrario.
}})
})

:: Créditos: Eu

Nerdzinhu
Thunder Cat
Thunder Cat

Masculino Posts: 265
Rate: Iniciante
Idade: 16
Localização: ROOM

http://www.kromusdesign.com http://bg-games.forumeiro.com

Voltar ao Topo Ir em baixo

Re: [Tutorial] Efeito para menu (jQuery)

Mensagem por GabrielMoon em Seg Fev 13, 2012 5:10 pm

Seria bom você hospeda tudo,e posta aqui.

GabrielMoon
Membro Fiel
Membro Fiel

Masculino Posts: 386
Rate: Sem rate
Idade: 15
Localização: RN,Natal.

http://gabriel-tavares.deviantart.com/ http://gabrieltavares.co.cc

Voltar ao Topo Ir em baixo

Re: [Tutorial] Efeito para menu (jQuery)

Mensagem por Rachel Green em Ter Fev 14, 2012 1:09 am

É só fazer as edições conforme ele ensinou no tutorial e hospedar. Pegar código hospedado em ouro local não é aconselhavel.



_________________________________________________________________________



Quem me dera ao menos uma vez
Provar que quem tem mais do que precisa ter quase sempre se convence que não tem o bastante
Fala demais por não ter nada a dizer.

Quem me dera ao menos uma vez
Que o mais simples fosse visto
Como o [u]mais importante[/u]
Mas nos deram espelhos e vimos um mundo doente.

Quem me dera ao menos uma vez
Fazer com que o mundo saiba que seu nome está em tudo e mesmo assim
Ninguém lhe diz ao menos, obrigado.




Rachel Green
Administradora
Administradora

Feminino Posts: 12068
Rate: Moderado
Idade: 20
Localização: Where the streets have no name

Voltar ao Topo Ir em baixo

Ver o tópico anterior Ver o tópico seguinte Voltar ao Topo


Permissão deste fórum:
Você não pode responder aos tópicos neste fórum