Foros del Web » Programando para Internet » Javascript »

Me funciona plegar desplegar un div pero quiero dos div y el segundo no me sale

Estas en el tema de Me funciona plegar desplegar un div pero quiero dos div y el segundo no me sale en el foro de Javascript en Foros del Web. Hola a todos, vereis tengo un script que me funciona muy bien pero quiero hacer una pequeña modificacion y no me sale. Tengo dos botones, ...
  #1 (permalink)  
Antiguo 13/04/2012, 03:18
 
Fecha de Ingreso: febrero-2010
Mensajes: 47
Antigüedad: 14 años, 9 meses
Puntos: 1
Me funciona plegar desplegar un div pero quiero dos div y el segundo no me sale

Hola a todos, vereis tengo un script que me funciona muy bien pero quiero hacer una pequeña modificacion y no me sale.

Tengo dos botones, uno para desplegar y otro para ocultar un div. el tema es que necesito tener dos div, y que los dos puedan acceder a esta funcion, pero no se diferenciarlos al principio de la funcion para decirle que lo haga solo en el que he pulsado. Aqui el codigo por si alguien me puede decir como puedo hacer esa condicion.

Código HTML:
<!-- AQUI LOS DOS BOTONES Y EL DIV (FUNCIONA PERFECT)-->


<div id="botones" style="width:600px; height:20px;">

<input type="image" id="recoger" onclick="plegar()" src="imagenes/up.gif"/>
<input type="image" id="desplegar" onclick="desplegar()" src="imagenes/down.gif" /> 

</div>


<div id="contenido" style="width:720px; height:305px; background-color:#006699; position:relative;"></div>



/* aqui el javascript*/

<script language="javascript" type="text/javascript">

var temporizadorplegar;
var temporizadordesplegar;

function plegar(){
clearTimeout(temporizadordesplegar);
var altura=parseInt(document.getElementById("contenido").style.height);

if(altura>0)
{
altura--;
document.getElementById("contenido").style.height=altura+"px";
temporizadorplegar=setTimeout("plegar()",1);
}
else
{ 
clearTimeout(temporizadorplegar);
}
}

function desplegar(){
clearTimeout(temporizadorplegar);
var altura=parseInt(document.getElementById("contenido").style.height);

if(altura<305){
altura++;
document.getElementById("contenido").style.height=altura+"px";
temporizadordesplegar=setTimeout("desplegar()",1);
}
else
{
clearTimeout(temporizadordesplegar);
}
}

</script> 
Como puedo hacer para añadir otro div con sus respectivos botones.....y que la funcion sepa discriminar???
  #2 (permalink)  
Antiguo 13/04/2012, 03:43
Avatar de zalito12  
Fecha de Ingreso: noviembre-2011
Ubicación: Coruña, España
Mensajes: 430
Antigüedad: 13 años
Puntos: 67
Respuesta: Me funciona plegar desplegar un div pero quiero dos div y el segundo no me

Prueba esto, debería funcionar:
Código PHP:
<!-- AQUI LOS DOS BOTONES Y EL DIV (FUNCIONA PERFECT)-->


<
div id="botones" style="width:600px; height:20px;">

<
input type="image" id="recoger" onclick="plegar('contenido')" src="imagenes/up.gif"/>
<
input type="image" id="desplegar" onclick="desplegar('contenido')" src="imagenes/down.gif" /> 

</
div>


<
div id="contenido" style="width:720px; height:305px; background-color:#006699; position:relative;"></div>


<
div id="botones" style="width:600px; height:20px;">

<
input type="image" id="recoger" onclick="plegar('otroDiv')" src="imagenes/up.gif"/>
<
input type="image" id="desplegar" onclick="desplegar('otroDiv')" src="imagenes/down.gif" /> 

</
div>

<
div id="otroDiv" style="width:720px; height:305px; background-color:#006699; position:relative;"></div>



/* aqui el javascript*/

<script language="javascript" type="text/javascript">

var 
temporizadorplegar;
var 
temporizadordesplegar;

function 
plegar(objeto){
clearTimeout(temporizadordesplegar);
var 
altura=parseInt(document.getElementById(objeto).style.height);

if(
altura>0)
{
altura--;
document.getElementById(objeto).style.height=altura+"px";
temporizadorplegar=setTimeout("plegar()",1);
}
else

clearTimeout(temporizadorplegar);
}
}

function 
desplegar(objeto){
clearTimeout(temporizadorplegar);
var 
altura=parseInt(document.getElementById(objeto).style.height);

if(
altura<305){
altura++;
document.getElementById(objeto).style.height=altura+"px";
temporizadordesplegar=setTimeout("desplegar()",1);
}
else
{
clearTimeout(temporizadordesplegar);
}
}

</script> 
Eso es usar parámetros en las funciones.
  #3 (permalink)  
Antiguo 13/04/2012, 03:47
Avatar de TheScript  
Fecha de Ingreso: septiembre-2011
Ubicación: Spain
Mensajes: 164
Antigüedad: 13 años, 2 meses
Puntos: 30
Respuesta: Me funciona plegar desplegar un div pero quiero dos div y el segundo no me

Hola carmen andaba buscando algo parecido a lo que estás intentando hacer, probé tu script y la verdad es que me ha venido bien ¡! jejejejejeje yo soy mas de php y tengo problemillas la verdad para aclararme con js, si consigues terminarlo ¿podrías postearlo aqui? si consigo hacer que funcione yo tb lo pondre. un saludo.

Aui te dejo el que estaba haciendo yo, pero claro, el tuyo con el timeout se queda mucho mas bonito que el mio, y aun no le apliqué el tamaño ni nada, es un tamaño fijo de un div dentro de otro que es el que se oculta y muestra.

Código HTML:
<script language="JavaScript">
function muestra_oculta(id){
if (document.getElementById){ //se obtiene el id
var el = document.getElementById(id); //se define la variable "el" igual a nuestro div
el.style.display = (el.style.display == 'none') ? 'block' : 'none'; //damos un atributo display:none que oculta el div
}
}
window.onload = function(){/*hace que se cargue la función lo que predetermina que div estará oculto hasta llamar a la función nuevamente*/
muestra_oculta('contenido_a_mostrar');/* "contenido_a_mostrar" es el nombre que le dimos al DIV */
}
</script>

</head>

<body>

<!--Al hace llamado a la función solo tienes que idicar el nombre del DIV entre parentesis -->
<p><a href="#" onClick="muestra_oculta('contenido_a_mostrar')" title="">Mostrar / Ocultar</a></p>

<div id="contenido_a_mostrar">
<p>Este contenido tiene que mostrarse con el link</p>
</div>
<div>hola que pasa esto es una prueba a ver si se desplaza</div> 
  #4 (permalink)  
Antiguo 13/04/2012, 03:52
 
Fecha de Ingreso: febrero-2010
Mensajes: 47
Antigüedad: 14 años, 9 meses
Puntos: 1
Respuesta: Me funciona plegar desplegar un div pero quiero dos div y el segundo no me

Hola Zalito12 y Script gracias por contestarme! jejeje probé la respuesta de Zalito12 y en la consola de errores me muestra este error:

Cita:
Uncaught TypeError: Cannot read property 'style' of null
De verdad que este tema me está tocando el orgullo y la moral!!! Que inutil soy cuando quiero!!
  #5 (permalink)  
Antiguo 13/04/2012, 04:21
Avatar de zalito12  
Fecha de Ingreso: noviembre-2011
Ubicación: Coruña, España
Mensajes: 430
Antigüedad: 13 años
Puntos: 67
Respuesta: Me funciona plegar desplegar un div pero quiero dos div y el segundo no me

Pero has cambiado tambien esto?
<div id="botones" style="width:600px; height:20px;">

<input type="image" id="recoger" onclick="plegar('contenido')" src="imagenes/up.gif"/>
<input type="image" id="desplegar" onclick="desplegar('contenido')" src="imagenes/down.gif" />

</div>

Etiquetas: desplegar, funcion, input, quiero
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 04:30.