Foros del Web » Programando para Internet » Jquery »

Ejecucion de jquery a medias

Estas en el tema de Ejecucion de jquery a medias en el foro de Jquery en Foros del Web. Hola amigos! Tengo un menu en el que aplico los siguientes efectos: <script> $(function(){ $('.primer_nivel a').hover(function () { $(this).stop().animate({ backgroundColor: "#fff", color: "#000" }, 400); ...
  #1 (permalink)  
Antiguo 26/12/2012, 12:10
 
Fecha de Ingreso: septiembre-2010
Mensajes: 79
Antigüedad: 13 años, 7 meses
Puntos: 1
Ejecucion de jquery a medias

Hola amigos!

Tengo un menu en el que aplico los siguientes efectos:

<script>
$(function(){
$('.primer_nivel a').hover(function () {
$(this).stop().animate({
backgroundColor: "#fff",
color: "#000"
}, 400);
},function() {
$(this).stop().animate({
backgroundColor: "#000",
color:"#fff"
}, 400);
});
});

$(function(){
$('.primer_nivel').hover(function () {
$(this).find('.submenu').stop().slideToggle('slow' );
});
});

$(function(){
$('.submenu .segundo_nivel').hover(function () {
$(this).find('.submenu2').stop().slideToggle('fast ');
});
});
</script>

La primera funcion simplemente cambia el color. El tema es que en la tercera función, si paso el ratón rapidamente desde un elemento de primer nivel a uno de segundo nivel a veces me realiza la animación slideToggle a medias i solo se ve la mitad de esas pestañas. Saben a que puede ser debido???

Gracias de antemano!!
  #2 (permalink)  
Antiguo 26/12/2012, 13:39
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 11 meses
Puntos: 1517
Respuesta: Ejecucion de jquery a medias

Desconozco, pero ¿si aplicas algún reset cuando salgas completamente de los tags? También desconozco como lograr un reset, tal vez alguna persona con más experiencia pueda indicarte, pero si quieres puedes ir adelantando como lograr hacer un reset de la animación.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #3 (permalink)  
Antiguo 26/12/2012, 13:42
 
Fecha de Ingreso: septiembre-2010
Mensajes: 79
Antigüedad: 13 años, 7 meses
Puntos: 1
Respuesta: Ejecucion de jquery a medias

Eso estaria bien.. Gracias por tu aporte
  #4 (permalink)  
Antiguo 26/12/2012, 16:48
Avatar de NUCKLEAR
Moderador radioactivo
 
Fecha de Ingreso: octubre-2005
Ubicación: Cordoba-Argentina
Mensajes: 5.688
Antigüedad: 18 años, 5 meses
Puntos: 890
Respuesta: Ejecucion de jquery a medias

Deberias aprender a preguntar, yo entiendo lo que quieres hacer, pero ese script es inleible...
Pon todo completo, el html que usas, la porción de css si usas algo y obviamente el script... http://jsfiddle.net/
__________________
Drupal Argentina
  #5 (permalink)  
Antiguo 27/12/2012, 02:10
 
Fecha de Ingreso: septiembre-2010
Mensajes: 79
Antigüedad: 13 años, 7 meses
Puntos: 1
Respuesta: Ejecucion de jquery a medias

Tienes razón Nucklear. Aqui va el código:

Javascript:

<script type="text/javascript">

$(function(){
$('.primer_nivel').hover(function () {
$(this).find('.submenu').stop().slideToggle('slow' );
});
});

$(function(){
$('.segundo_nivel').hover(function () {
$(this).find('.submenu2').stop().show('slow');
},function(){
$(this).find('.submenu2').stop().hide('fast');
});
});
</script>

HTML (Menu con 2 niveles internos):

<ul>
<li class="primer_nivel"><a href=""></a></li>
<li class="primer_nivel"><a href=""></a></li>
<li class="primer_nivel">
<a href=""></a>
<ul class="submenu">
<li class="segundo_nivel"><a href=""></a></li>
<li class="segundo_nivel"><a href=""></a></li>
<li class="segundo_nivel"><a href=""></a></li>
<li class="segundo_nivel"><a href=""></a></li>
<li class="segundo_nivel">
<a href="">Muebles de baño >></a>
<ul class="submenu2">
<li><a href=""></a></li>
<li><a href=""></a></li>
<li><a href=""></a></li>
<li><a href=""></a></li>
</ul>
</li>
</ul>

CSS:

nav ul .primer_nivel{
float: left;
margin: 0px 5px;
position: relative;
}
nav ul .primer_nivel:first-child{
margin-left: 0px;
}
nav ul .primer_nivel a{
/*border:1px solid black;*/
border-radius: 5px;
font-family: 'Quicksand', sans-serif;
font-weight: normal;
padding:5px 15px;
color: #fff;
text-decoration: none;
font-size: 16px;
}

nav ul .primer_nivel .submenu{
position: absolute;
display: none;
width: 300px;
z-index: 1000;
margin-top:5px;
left:-5px;
}
.submenu .segundo_nivel{position: relative;}
.submenu .segundo_nivel:first-child{
/*margin-left: 5px;*/
}
.submenu a{
/*padding: 10px 20px 10px 20px;*/
background-color: #000;
color:white;
display: block;
width: 200px;
text-align: center;
margin-top:3px;
}

.submenu2{
position:absolute;
display:none;
left:232px;
top:-5px;
width:200px;
}
.submenu2 li a{margin-top: 1px;}



He probado la herramienta que adjuntabas en el anterior mensaje (jsFiddle, muy buena por cierto) y no me da ese error normalmente, pero cuando entro en el último nivel del menú desaparece rápidamente esa lista (Como si no detectase bien el hover).

Bueno espero sus aportes, saludos!!!

Última edición por vorox; 27/12/2012 a las 02:20 Razón: Faltaba información.
  #6 (permalink)  
Antiguo 27/12/2012, 13:50
 
Fecha de Ingreso: septiembre-2010
Mensajes: 79
Antigüedad: 13 años, 7 meses
Puntos: 1
Respuesta: Ejecucion de jquery a medias

Ya esta solucionado, por si a alguien le interesa, al método stop() de jquery hay que pasarle unos valores booleanos para que la función limpie la cola de animación (primer true) y un segundo valor para que salte al final de la ejecución: stop(true, true)

Fuente: http://api.jquery.com/stop/

Saludos!

Etiquetas: ejecucion, funcion, medias
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 15:35.