Foros del Web » Programando para Internet » Javascript »

Mostar - Ocultar DIV - Problema con OnMouseOut.

Estas en el tema de Mostar - Ocultar DIV - Problema con OnMouseOut. en el foro de Javascript en Foros del Web. Hola a todos. Tengo un Div en la parte izquierda de la web, y dentro de el una tabla que simula un Menú. El típico ...
  #1 (permalink)  
Antiguo 23/01/2009, 10:43
 
Fecha de Ingreso: enero-2009
Mensajes: 14
Antigüedad: 15 años, 10 meses
Puntos: 0
Exclamación Mostar - Ocultar DIV - Problema con OnMouseOut.

Hola a todos.

Tengo un Div en la parte izquierda de la web, y dentro de el una tabla que simula un Menú. El típico menú de la izquierda.
Al pasar por algunas celdas de esa tabla (menú), quiero que se descubra otro Div, anexo al primero, pero a su derecha para que parezca un submenú, ¿me entendéis?
Y que cuando se deje de pasar por esa celda, se oculte.

El código sería algo similar a esto:

Código:
<div id="menu">
  <table id="tabla_menu">
     <tr>
        <td></td>
     </tr>
     <tr>
        <td></td>
     </tr>
 </table>
</div>

<div id="submenu" style="position:absolute; top=x1;left=y1; visibility:hidden;">
Entonces mi problema es el siguiente:
Quiero que el DIV "submenu" se descubra cuando hago "onMouseover" sobre un TD de la tabla, y se oculte cuando salgo de él.
En principio, lo que he intentado del siguiente modo:

Código:
<td onmouseover:"mostrar();" onmouseout:"ocultar();">
Donde "mostrar" y "ocultar" son dos funciones Javascript triviales que hacen esto:

elemento.style.visibility = 'hidden' ó = 'visible'.

PROBLEMA:
Cuando salgo de la celda se desencadena el evento onMouseOut INCLUSO cuando salgo del TD hacia el DIV "submenu" que se acaba de descubrir. Entonces no puedo hacer uso de ninguna opción que aparece ahí ya que cuando me dirijo hacia ese DIV al desencadenarse el evento onMouseout se oculta.

¿Cómo puedo evitar que se oculta el DIV en esa circunstancia?

Gracias por adelantado.
  #2 (permalink)  
Antiguo 23/01/2009, 11:58
 
Fecha de Ingreso: enero-2008
Mensajes: 614
Antigüedad: 16 años, 10 meses
Puntos: 57
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

Cuando sales del TD (o sea, cuando se ejecuta onmouseout) tienes que poner un "retraso" para ocultar el DIV. Y cuando entres al DIV (submenu), si aun esta activo el retraso, lo eliminas y ya no se va a ocultar.
  1. En el onmouseout del TD, crear temporizador para ocultar el submenu
  2. En el evento onmouseover del submenu, desactivar el temporizador que oculta el submenu
  3. En el onmouseout del submenu, ocultar el mismo submenu

Puedes utilizar la funcion setTimeout para retardar un poco el ocultar el DIV. Despues tienes que usar la funcion clearTimeout para desactivar el temporizador. Puedes ser algo como esto:

Código:
<td onmouseover="mostrar();" onmouseout="tempo=setTimeout('ocultar();',1000);">
...
Esto creara un temporizador (tempo) que ejecutara la funcion ocultar() un segundo despues que el mouse salio del TD. Ahora, en el submenu, tienes que poner:

Código:
<div id="menu" onmouseover="clearTimeout(tempo);" onmouseout="ocultar();">
...

Última edición por posman; 23/01/2009 a las 12:05
  #3 (permalink)  
Antiguo 26/01/2009, 05:34
 
Fecha de Ingreso: enero-2009
Mensajes: 14
Antigüedad: 15 años, 10 meses
Puntos: 0
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

Hola.

Gracias por tu respuesta, he avanzado algo pero sigue sin funcionar.

Por el tema de la jerarquía de eventos o algo así, no funciona bien.

Dentro del TD del Menú principal:

Código:
<td onmouseover="mostrar();" onmouseout="tempo=setTimeout('ocultar();',2000);"><a href="#">&bull; LINK</a></td>
.
como ves hay un Link.

Y dentro del DIV del SubMenú, hay otra TABLE con sus TDs.

No sé por que será, pero el DIV se oculta todo el rato la mayoría de las veces, incluso cuando estoy en el TD del código que he puesto (el del menú principal) si dentro de él, paso por encima del Link (<a></a>) también se oculta.

No sé practicamente nada acerca de controlar los eventos. ¿es problema de esto, o qué solución puede haber?
  #4 (permalink)  
Antiguo 26/01/2009, 07:59
Avatar de Dalvenjha  
Fecha de Ingreso: febrero-2008
Ubicación: $("#oficina");
Mensajes: 692
Antigüedad: 16 años, 9 meses
Puntos: 53
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

Lo que buscas es ocultar y mostrar un div cuando se haga onmouseover en tu div no?, ya he puesto algunos códigos sobre eso aqui, asi que voy a buscarlos, voy a tratar de responderte nuevamente al toque ok?

Saludos!!
__________________
Mi Showcase ||

Compartiendo todo lo posible con los demás.
  #5 (permalink)  
Antiguo 26/01/2009, 08:12
Avatar de Dalvenjha  
Fecha de Ingreso: febrero-2008
Ubicación: $("#oficina");
Mensajes: 692
Antigüedad: 16 años, 9 meses
Puntos: 53
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

Listo, encontré lo que postee (Qué flojo soy para reescribir) a ver vamos por partes, te propongo que replantees tu script que muestra o esconde los divs, podrías usar este, y te ahorraría ese problema.

Código:
<script type="text/javascript">
objeto = 'uno';
function enseñar(enseñame){
document.getElementById(objeto).style.display="none";
document.getElementById(enseñame).style.display="block";
objeto=enseñame;
}
</script>
Y la llamada sería:
<li onmouseover="enseñar('uno');">ver uno</li>
<li onmouseover="enseñar('dos');">ver dos</li>
<li onmouseover="enseñar('tres');">ver tres</li>
<li onmouseover="enseñar('cuatro');">ver cuatro</li>
Asi lo que hace, es capturar el div que está con el display block, y cambiarlo a none, y luego poner en block el que estás llamando. El efecto es un tanto abrupto, pero si quieres algo como un fade, podría darte una mano también, pero primero revisa esto y luego me pasas la voz para que lo adaptemos a tu estructura.

Cualquier pregunta hasla por aqui.

Saludos!!
__________________
Mi Showcase ||

Compartiendo todo lo posible con los demás.
  #6 (permalink)  
Antiguo 27/01/2009, 05:12
 
Fecha de Ingreso: enero-2009
Mensajes: 14
Antigüedad: 15 años, 10 meses
Puntos: 0
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

Hola de nuevo.

Gracias Dalvenjha por tu sugerencia.

Contamplo tu idea, y me preparo para cambiar el "chip" si no resuelvo finalmente mi planteamiento, pero es que, antes de reestructurar el menú, me gustaría dar con la solución a esto ya que, no puede ser nada ultracomplejo, ya que tengo el Div del submenú colocado y todo, y se oculta y desoculta pero no cuando quiero :(

Mira, os paso un enlace donde colgaré la página para que la echéis un ojo y veais el comportamiento del submenú, ¿ok? y así de paso, podáis acceder de primera mano al código para echarle un ojo, quien quiera.

http://80.37.222.172:8080/Remo/index.html

Y aquí el .js:
http://80.37.222.172:8080/Remo/scripts/menu.js

Observar el comportamiento del SubMenú de marras (que es el que aparece al pasar por encima de NACIMIENTO).
Observar también, que el Submenú que se despliega (FUNDADORES y 1ª REGATA) es una tabla contenida en un DIV. Pues bien, al pasar del primer TD (FUNDADORES) al segundo TD (1ª REGATA) (que están ambos contenidos en el mismo DIV) el Submenú se oculta. Interpreta el onMouseout del DIV, pero ¡¡SIN SALIR DE ÉL!!

Espero que por favor, me podáis ayudar, no puede ser tan complicado algo tam común en el WEB! Y me fastidia no dar con ello.

GRACIAS!!
  #7 (permalink)  
Antiguo 27/01/2009, 11:23
 
Fecha de Ingreso: enero-2009
Mensajes: 14
Antigüedad: 15 años, 10 meses
Puntos: 0
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

¡¡SOLUCIONADO!!

Después de horas y horas investigando, ¡¡¡el menú ya tiene la funcionalidad deseada!!!

He empleado el concepto que me dió posman, el del retardo. Sólo que, en vez de crear la variable "tempo" en la propia llamada a la función, la creo de forma global en la hoja de código .js.

Además, he creado otra función, "oculta_retarda". Esta nueva función llama a la función "oculta()" (la normal) pasados los milisegundos que ponga en el setTimeout y a "oculta_retarda" la llamo sólo cuando salgo del TD.
Cuando salgo del DIV (submenu) llamo sencillamente a "oculta()" ya que no quiero que se vea más.

Este es el código resultante del TD del menú principal:
Código:
<td onmouseover="mostrar_nacimiento();" onmouseout="ocultar_retarda();"><a href="#">&bull; NACIMIENTO</a></td>
Este es el código del DIV del SubMenú:
Código:
<div id="apDiv1" onmouseover="mostrar_nacimiento();" onmouseout="ocultar_nacimiento();">
Y este, el código JavaScript asociado:
Código:
	var tempo=0;
	
	function mostrar_nacimiento()
		{
		var subMenu = document.getElementById('apDiv1');
		subMenu.style.visibility = 'visible';
		clearTimeout(tempo);
		}

	function ocultar_nacimiento()
		{
		var subMenu = document.getElementById('apDiv1');
		subMenu.style.visibility = 'hidden';
		}
		
	function ocultar_retarda()
		{
		tempo=setTimeout("ocultar_nacimiento();",1);		
		}
¡GRACIAS A TODOS! en especial a Dalvenjha y posman.
  #8 (permalink)  
Antiguo 24/05/2013, 02:42
 
Fecha de Ingreso: septiembre-2012
Mensajes: 30
Antigüedad: 12 años, 2 meses
Puntos: 0
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

Tengo un mapa de imagen dónde tengo varias zonas que al pasar por encima se despliega un submenu. He implementado el código de mitshu y funciona de maravilla, lo único es que no sé como modificar el código para que me sirva para todos los submenus, Tal como esta solo me sirve para un div concreto.

¿Que debo poner para que coja la id de la capa a mostrar/ocultar automaticamente?
  #9 (permalink)  
Antiguo 24/05/2013, 12:53
 
Fecha de Ingreso: abril-2011
Mensajes: 1.342
Antigüedad: 13 años, 6 meses
Puntos: 344
Respuesta: Mostar - Ocultar DIV - Problema con OnMouseOut.

No deberías reabrir temas que son de hace tanto tiempo, sino abrir otro tema.

Aun así, te paso como podrías hacerlo:

Código Javascript:
Ver original
  1. function hideElement(element)
  2. {      
  3.         element.style.visibility = 'hidden';
  4. }
  5.  
  6. function showMenu(selectedElementId,showElementId)
  7. {
  8.     var tempo=0;
  9.    
  10.     var selectedElement = document.getElementById(selectedElementId);
  11.     var showElement = document.getElementById(showElementId);
  12.    
  13.     if (selectedElement && showElement)
  14.     {
  15.         selectedElement.onmouseover = showElement.onmouseover = function()
  16.         {
  17.             showElement.style.visibility = 'visible';
  18.             clearTimeout(tempo);
  19.         }
  20.        
  21.         selectedElement.onmouseout =  showElement.onmouseout = function()
  22.         {
  23.             tempo = setTimeout(function() { hideElement(showElement); },100);      
  24.         }    
  25.     }    
  26. }
  27.  
  28. //El primer parámetro es el id del elemento que hace aparecer el elemento cuyo id es el segundo parámetro
  29. showMenu("menu","submenu");

Un saludo.
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 18:36.