Foros del Web » Programando para Internet » Jquery »

Problema con función al mostrar/ocultar div

Estas en el tema de Problema con función al mostrar/ocultar div en el foro de Jquery en Foros del Web. Hola!! Os ruego me ayudéis, no sé como solucionarlo. Tengo una función que oculta y muestra div's jugando con el left. Funciona, pero el problema ...
  #1 (permalink)  
Antiguo 11/09/2014, 05:25
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Pregunta Problema con función al mostrar/ocultar div

Hola!!

Os ruego me ayudéis, no sé como solucionarlo.

Tengo una función que oculta y muestra div's jugando con el left.

Funciona, pero el problema me viene cuando he incluido un plugin de Jquery para mostrar un menú tipo slider en toda la Web.

Si hago uso del menú me deja de funcionar la función de manera correcta, ya que me sigue mostrarn los div's, pero fuera de la pantalla, no sé que hacer.

Esta es la página: http://macoex.es/index2.asp

Si al entrar, pincháis en las llaves de arriba a la derecha, veréis que aparece un div con el formulario de logado, lo podéis hacer 100 veces que funciona

Probad a pinchar en el icono de menú de la izquierda, este aparecerá, si pincháis de nuevo se oculta.

Bien, si ahora pincháis en las llaves de nuevo, veréis que ya no aparece el Div para logarse.

¿Me podéis ayudar por favor?
  #2 (permalink)  
Antiguo 11/09/2014, 20:53
(Desactivado)
 
Fecha de Ingreso: abril-2013
Ubicación: rosario
Mensajes: 248
Antigüedad: 11 años, 7 meses
Puntos: 17
Respuesta: Problema con función al mostrar/ocultar div

Hola pablo, primero gracias x dejar la url de tu sitio y asi poder reproducir el error, te comento lo que vi, veo que al atributo wrapper de la llamada al plugin simpleSidebar vos le pones como valor el id del div "continente", por lo tanto, como continente no es wrapper de tu div id sidebar, lo que hace es aplicar los estilos a todos los div q encuentre y dentro de esos div esta el de login id id_index_login, si lo examinas con firebug vas a ver q le aplica un margn-left 75 y eso hace q no lo veas en pantalla, pero en realidad esta.
En fin, yo te diria que revises el index2.asp y lo q tenes q hacer es ver q el div id=continente encierre a todos los demas y si no crear un div cualquiera que encierre al div id=slider y luego modificar el atributo del plugin simpleSidebar ej wrapper: "#nuevo div"
No se si fui claro, cualquier cosa me avisas.
  #3 (permalink)  
Antiguo 12/09/2014, 01:05
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema con función al mostrar/ocultar div

Muchas gracias, claro clarísimo. Tienes razón, pero no sé como estructurar mi html

La estructura es la siguiente
-html
- -body
- - - continente
- - - - Contenido
- - - div barrafija
- - - div login
- - - div suscripción
- - - div slidebar

los div ocultos o fijos los saco fuera del contenido y sin embargo barrafija y suscripción no se ven afectados. Si bajas del todo, verás que te aparece el formulario de suscripción y éste no se ve afectado nunca muestres y ocultes el slidebar antes o después.

¿cual sería la estructura correcta?
¿Es un problema de estructura o bien se puede solucionar tocando el CSS?
  #4 (permalink)  
Antiguo 12/09/2014, 01:10
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema con función al mostrar/ocultar div

Perdón, pongo la estructura completa:

La estructura es la siguiente
-html
- -body
- - - continente
- - - - Contenido
- - - - - Resto del html
- - - Footer
- - - div barrafija
- - - div login
- - - div suscripción
- - - div slidebar

El pie tampoco se ve afectado.
  #5 (permalink)  
Antiguo 12/09/2014, 02:01
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema con función al mostrar/ocultar div

He probado lo siguiente y pasa igual

He metido el Nav del slidebar en un aside, lo he llamado Id="wrapper_slidebar" y el plugin le he dado ese wrapper:

Código Javascript:
Ver original
  1. <script>
  2.         $(document).ready(function(){
  3.             $( "#sidebar" ).simpleSidebar({
  4.               settings: {
  5.                 opener: "#open-sb",
  6.                 wrapper: "#wrapper_slidebar",
  7.                 animation: {
  8.                   easing: "easeOutQuint"
  9.                 }
  10.               },
  11.               sidebar: {
  12.                 align: "left",
  13.                 width: 400,
  14.                 closingLinks: 'a',
  15.               }
  16.             });
  17.         });
  18.     </script>

Pasa lo mismo, con la diferencia, claro está, que el continente no se mueve a la derecha, ni ningún otro div, tan solo el div oculto. No lo entiendo.
  #6 (permalink)  
Antiguo 12/09/2014, 02:05
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema con función al mostrar/ocultar div

En el div oculto de logado se modifica el DOM a través de Jquery, ¿no tendrá algo que ver?

Código Javascript:
Ver original
  1. <script type="text/javascript">
  2.             function muestra_oculta(id) {
  3.             //compruebo si el elemto esta oculto o no
  4.                if($('#'+id).is(':hidden')) {
  5.                    $('#'+id).show('slow');
  6.                }else {// de lo contrario lo oculto
  7.                    $('#'+id).hide('slow');
  8.                }
  9.             }
  10.         </script>

Código HTML:
Ver original
  1. <div class="div_subcontenido_g div_hidden" id="id_index_login">
  2.             <a onclick="muestra_oculta('id_index_login')"><img title="Cerrar" alt="Cerrar" src="<%=Imagessys()%>/ico24_close.png"/></a>
  3.            
  4.             <form class="formulario" action="usr_registro.asp?proceso=login&pag=<%=Nombre_Pagina%>" method="post" language="JavaScript" name="FrontPage_Form1" onsubmit="return FrontPage_Form1_Validator(this)">
  5.                 <fieldset>
  6. .
  7. .
  8. .
  9.             </form>
  10.            
  11.             <div>
  12.                 <p><img alt="Key" src="<%=Imagessys()%>/ico16_key.png"/>  <a href="usr_registro.asp?proceso=recpass">Recuperar contraseña</a></p>
  13.                 <p><img alt="Key" src="<%=Imagessys()%>/ico16_user.png"/>  ¿Aún no tiene cuenta? <a href="usr_registro.asp">Regístrese</a></p>
  14.          
  15.             </div>
  16.            
  17.         </div>
  #7 (permalink)  
Antiguo 12/09/2014, 06:25
(Desactivado)
 
Fecha de Ingreso: abril-2013
Ubicación: rosario
Mensajes: 248
Antigüedad: 11 años, 7 meses
Puntos: 17
Respuesta: Problema con función al mostrar/ocultar div

para mi el div id contenido debe contener a todos, incluso los div q estan ocultos, ahora en un rato me bajo el plugin y lo pruebo y luego te aviso
  #8 (permalink)  
Antiguo 12/09/2014, 09:19
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema con función al mostrar/ocultar div

Muchas gracias!! Son muchos los clientes que tienen el mismo CMS, gracias de verdad.
  #9 (permalink)  
Antiguo 12/09/2014, 16:33
(Desactivado)
 
Fecha de Ingreso: abril-2013
Ubicación: rosario
Mensajes: 248
Antigüedad: 11 años, 7 meses
Puntos: 17
Respuesta: Problema con función al mostrar/ocultar div

pablo, si te animas hacer una prueba hace esto, en tu hoja de estilo estilomatriz.css
busca esta clase .div_hidden y modifica el left a 15% y elimina el margin-left es decir que quede asi
Código:
.div_hidden {
    background-color: white;
    border: 1px solid gray;
    border-radius: 3px;
    box-shadow: 0 0 7px 0 #000000;
    display: none;
    height: 80%;
    left: 15%;
    overflow: auto;
    position: fixed;
    top: 7%;
    width: 75%;
    z-index: 100;
}
rompe cookies , probalo y me avisas!!!
  #10 (permalink)  
Antiguo 15/09/2014, 01:45
 
Fecha de Ingreso: diciembre-2010
Mensajes: 236
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema con función al mostrar/ocultar div

Funciona!!!

Css final, para que los demás veáis el cambio. Menuda tontería, cómo no me ha dado por probar ahí, me centré en los plugins y en Js. Muchas gracias Diurno, me has quitado un buen marrón de encima. Un saludo!!!


Código CSS:
Ver original
  1. .div_hidden {
  2.     display: none;
  3.     position: fixed;
  4.     background-color: white;
  5.     z-index: 100;
  6.        
  7.     top: 7%;
  8.     height:80%;
  9.    
  10.     width:75%;
  11.    
  12.    
  13.     border: solid 1px gray;
  14.     border-radius: 3px;
  15.     box-shadow: 0 0 7px 0 #000000; 
  16.     overflow: auto;
  17.    
  18.     /*
  19.     left: 100%;
  20.     margin-left: -90%;
  21.     */
  22.    
  23.     left: 15%;
  24.  
  25. }

Etiquetas: Ninguno
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 08:52.