Ver Mensaje Individual
  #1 (permalink)  
Antiguo 25/11/2011, 16:06
oms02
 
Fecha de Ingreso: junio-2010
Mensajes: 373
Antigüedad: 14 años, 6 meses
Puntos: 11
problema con datos en div que ha sido borrado previamente

Hola a todos. Veréis, tengo un problema que me esta trayendo por la calle de la amargura. A ver si me podéis echar un cable. Os comento:

En esencia se trata de un php en el que se ejecuta una función javascript. El javascript se trata simplemente de un reloj (digital) que se muestra en una serie de divs.

Ahora, (con el javascript ejecutándose), tengo un botón (html) en el que, al pulsar, la función (el reloj js) vuelve a ejecutarse de nuevo; es decir, el reloj empieza de nuevo. El proceso que realizo concretamente es esconder el div contenedor donde esta el reloj, ejecutar la función y mostrar de nuevo los divs.

Bueno, el maldito problema es que todo funciona casi perfecto, a excepción de que al darle al botón, en esa serie de divs se muestran los dos relojes.

Me imagino donde está la raíz del problema y es que al volver a llamarse al mismo código, los divs donde deben mostrarse los dígitos del reloj son los mismos donde antes se mostraba el antiguo reloj (los muestro por la clase y diferencio los digitos por el id).

He tratado de quitar los divs con: remove(), empty(), hide(), y alguno mas…pero el resultado siempre es el mismo: se acaban mostrando (en los mismos divs) los 2 relojes a la vez.


Aqui los codigos con el proceso completo:
El php que se ejecuta al principio:
Código HTML:
Ver original
  1. <div id="resultado">
  2. <?php require ('reloj.php'); ?>//llamo al archivo donde se ejecuta el reloj
  3. </div>


reloj.php
Código HTML:
Ver original
  1. <!-- aqui hay codigo php previo pero no influye para nada en el problema. -->
  2.  
  3. <div class="cuadro-reloj">
  4.     <script type="text/javascript">tiempo()</script>//funcion js del reloj
  5.     <div class="digito" id="dechora"></div>
  6.     <div class="digito" id="unihora"></div>
  7.     <div class="digito" id="dospuntos1"></div>
  8.     <div class="digito" id="decmin"></div>
  9.     <div class="digito" id="unimin"></div>
  10.     <div class="digito" id="dospuntos2"></div>
  11.     <div class="digito" id="decseg"></div>
  12.     <div class="digito" id="uniseg"></div>
  13. </div>


Ahora, mediante js (jquery), el evento que llama a ejecutar de nuevo la funcion si se hace click en el boton.
Código Javascript:
Ver original
  1. $("#boton-activar-reloj").live("click",function(){
  2.     $.ajax({
  3.         contentType: "application/x-www-form-urlencoded",
  4.         type: "POST",
  5.         url:'activarreloj.php',
  6.         data: "",
  7.         success: function(datos){
  8.             $('.cuadro-reloj').remove();//aqui he probado de todo...
  9.             $('#resultado').html(datos);
  10.         }
  11.     });
  12. });

El archivo activarreloj.php contiene también un require al archivo reloj.php
Código HTML:
Ver original
  1. ...
  2. <?php require ('reloj.php'); ?>//llamo al archivo donde se ejecuta el reloj

Supongo que para arreglar el problema sobran la mitad de los codigos que os he mostrado pero prefiero dejar claro el proceso.

A ver si me podeis echar una mano, porfa, que llevo varios dias con lo mismo y no hay manera. Muchas gracias por vuestro tiempo.

1 saludo!