IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Affichage de plusieurs Chrono en même temps


Sujet :

JavaScript

  1. #1
    Candidat au Club
    Femme Profil pro
    chef d'équipe
    Inscrit en
    Mars 2016
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : chef d'équipe

    Informations forums :
    Inscription : Mars 2016
    Messages : 3
    Points : 3
    Points
    3
    Par défaut Affichage de plusieurs Chrono en même temps
    Bonjour à tous,

    Suite à plusieurs tentatives sans résultats je fait appel à votre aide.

    Explications :

    Je suis en train de créer un site web (Jeux sur navigateur) et dans le tableau de bord des joueurs j'aimerai afficher, dans un tableau, les différents bâtiments qui sont en court d'amélioration avec le temps restant qui s'affiche dynamiquement via un script Javascript.

    Mon problème est que le temps s'affiche uniquement un seul fois quand j'ai plusieurs améliorations en court et le temps diminue 2 secondes par 2 secondes. Voir l'image ci-dessous.

    Nom : image.png
Affichages : 152
Taille : 7,5 Ko

    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    <table>
        <tr>
            <th colspan=2>Amélioration en cour</th>
        </tr>
        <tr>
            <th>Nom du bâtiment</th>
            <th>Temps</th>
        </tr>
        <?php
                $EncourAmelioration = $DB->query('SELECT * FROM ConstructionBat
                WHERE idjoueur = "'. $id_joueur .'"');
     
                while ($EncourAmelioration1 = $EncourAmelioration->fetch())
                          {
                               
                            $infoBat = $DB->query('SELECT * FROM Batiments WHERE id_bat = "'.$EncourAmelioration1['id_batiment'].'"' );
                            $infoBat1 = $infoBat->fetch(); 
                             
                             //Calcul du temps d'amélioration restant
                            $temps = intval(time());
                            $CalculTempsConstruction = $temps - $EncourAmelioration1['debut_construction'];
                             
                            $dateMySQL = $EncourAmelioration1['temps_construction'] - $CalculTempsConstruction;
                             
                            // Calcul du temps de construction
                            $t = $EncourAmelioration1['temps_construction'] ;
                            $s=$t%60; $t=($t-$s)/60;
                            $m=$t%60;
                            $h=($t-$m)/60;
                             
                             if($m<10){$m="0".$m;}
                             if($s<10){$s="0".$s;} 
                             ?>
     
     
                            <script type="text/javascript">
                            var tps = <?php echo $dateMySQL; ?>;
                            var h= 0;
                            var m= 0;
                            var s= 0;
                            var disp="";
                            var idtimer =setInterval('affichetemps()',1000);
                              
                            function affichetemps(){
                              
                              tps-- ;
                              h = parseInt(tps/3600) ;
                              m = parseInt((tps%3600)/60) ;
                              s = parseInt((tps%3600)%60) ;
                              disp = (h<10 ? "0"+h : h) + ' h ' + (m<10 ? "0"+m : m) + ' min ' + (s<10 ? "0"+s : s) + ' sec ';
                              document.getElementById('<?php echo $EncourAmelioration1['id_batiment']; ?>').innerHTML= disp;
                              
                               if ((h <= 0 && s <= 0 && m <=0)) {
                               clearInterval(idtimer);
                            url="http://www.streaming-world.fr/NewsSite/Modules/Batiments/fin_amelioration.php?id_batiment=<?php echo $id_bat; ?>&nommysql=<?php echo $info_batiments1['nom_mysql']; ?>&NomBat=<?php echo $NomBat; ?>&joueur=<?php echo $id_joueur; ?>&nivo=<?php echo $nivo; ?>&fichier=<?php echo $info_batiments1['fichier']; ?>"  // Changer ici l'url
                            Go(url)
                            }
                            }
                            function Go(url) {
                            //window.status="Go !"
                            //document.s.Time.value="Go !"
                            setTimeout("window.location=url", 400)
                            }
                            </script>
     
         <tr>
            <td> <?php echo $infoBat1['nom']; ?>
            </td>
            <td>
               <span style='color: green;'>
     
               <div id="<?php echo $EncourAmelioration1['id_batiment']; ?>" style="font-family: arial; size: 60px;"> </div></span>
     
            </td>
        </tr><?php } ?>
    </table>

    Avez-vous une idée??

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 056
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 056
    Points : 44 575
    Points
    44 575
    Par défaut
    Bonjour,
    tu peux avoir une fonction commune pour ton calcul et affichage du compte à rebours mais il te faut dans ce cas passer à la fonction un objet regroupant les données à traiter.
    Ces objets sont à créer côté serveur suivant le résultat de ta requête.

    En l'état de ton code je te conseilles de regarder le code HTML généré pour voir l'étendu des « dégâts » !

Discussions similaires

  1. [AC-2007] Affichage de plusieurs requête en même temps
    Par ALEX80800 dans le forum Access
    Réponses: 2
    Dernier message: 21/11/2011, 17h19
  2. Rendre visible / invisible plusieurs éléments en même temps
    Par Bluespike62 dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 23/01/2006, 17h43
  3. laisser cochés plusieurs TRadioButton en même temps.
    Par heider dans le forum Composants VCL
    Réponses: 5
    Dernier message: 25/12/2005, 14h15
  4. lecture de plusieurs port en même temps
    Par manaboko dans le forum Langage
    Réponses: 3
    Dernier message: 06/10/2005, 15h26
  5. Réponses: 9
    Dernier message: 17/04/2004, 16h32

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo