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 :

Décompte du temps restant avant function reloading


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 126
    Points : 57
    Points
    57
    Par défaut Décompte du temps restant avant function reloading
    Bonjour!
    J'ai actuellement la fonction suivante qui me permet de rafraîchir automatiquement la page en cours si "#autoreload" est placé dans l'adresse :
    Code : 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
     
    <script language="javascript" type="text/javascript">
    var reloading;
     
    function checkReloading() {
        if (window.location.hash=="#autoreload") {
            reloading=setTimeout("window.location.reload();", 300000);
            document.getElementById("reloadCB").checked=true;
        }
    }
     
    function toggleAutoRefresh(cb) {
        if (cb.checked) {
            window.location.replace("#autoreload");
            reloading=setTimeout("window.location.reload();", 300000);
        } else {
            window.location.replace("#");
            clearTimeout(reloading);
        }
    }
     
    window.onload=checkReloading;    
    </script>
    Je souhaiterais afficher au visiteur un décompte du temps qu'il reste (heure, minutes, secondes) avant réactualisation, est il possible de se prendre sur cette fonction ou l’exécution n'est pas la même (serveur/client)?
    Merci!

  2. #2
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 112
    Points
    44 112
    Par défaut
    Bonjour,
    ...est il possible de se prendre sur cette fonction ou l’exécution n'est pas la même (serveur/client)?
    en clair cela donne quoi comme question

  3. #3
    Expert éminent
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 093
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 093
    Points : 6 754
    Points
    6 754
    Par défaut
    Bonsoir,

    évite les chaînes dans setTimeout, passe plutôt par une fonction anonyme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    reloading=setTimeout(function(){ window.location.reload(); }, 300000);
    Edit: je crois avoir compris la question. Un setTimeout se fait côté client, le serveur n'est pas impliqué. Pour indiquer à l'utilisateur le temps restant avant le prochain rechargement, on peut lancer un second timer au même moment que le timer reloading. Ce second timer gèrera une fonction qui met à jour une horloge affichée sur la page.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    var $horloge = document.createElement("p");
    document.body.appendChild($horloge);
     
    var tempsRestant = 300000; // le même temps que pour reloading
                               // comme ce nombre apparaît plusieurs fois,
                               // il est sage d'utiliser à la place une variable
                               // déclarée une seule fois au début du code
     
    setInterval(function( ){
       tempsRestant -= 1000;
       var minutes = Math.floor(tempsRestant / 60000);
       var secondes = Math.floor(tempsRestant / 1000) % 60;
       if (secondes < 10) secondes = "0" + secondes;
       $horloge.textContent = minutes + ":" + secondes;
    }, 1000);
    Normalement on n'a pas besoin de gérer l'arrêt de ce timer car ça correspond au rechargement de la page. Mais il peut arriver qu'on voie un temps négatif pendant le rechargement. À toi de voir si c'est gênant ou pas.
    La FAQ JavaScript – Les cours JavaScript
    Touche F12 = la console → l’outil indispensable pour développer en JavaScript !

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 126
    Points : 57
    Points
    57
    Par défaut
    Salut et merci!
    Je n'étais vraiment pas clair apparemment !
    Le code précédemment annoncé recharge la page automatiquement toutes les 5 minutes (en réalité à +-30 secondes de précision !!!) et désolé Watilin, je ne manipule pas bien JS et ne parviens pas à le faire fonctionner avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    reloading=setTimeout(function(){ window.location.reload(); }, 300000);
    Ce décompte étant "caché", je souhaite simplement l'afficher au visiteur et de préference en se prenant sur le même timer afin d'éviter toute imprécision (0 c'est 0!)
    De plus Watilin, je n'arrive pas à faire fonctionner ton timer avec le précédent script

    Merci

  5. #5
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    ça ne s'appellerait pas un "compte à rebours" ??

    enfin si je devais chercher sur le forum c'est ce terme que j'utiliserais ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

Discussions similaires

  1. Connaître le temps restant avant la mise en veille
    Par dmganges dans le forum Windows
    Réponses: 2
    Dernier message: 29/06/2014, 15h13
  2. Compteur de temps restant avant un achat
    Par jzeel dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/03/2011, 16h38
  3. connaître le temps restant avant Ontimer
    Par OutOfRange dans le forum Composants VCL
    Réponses: 9
    Dernier message: 08/08/2007, 14h07
  4. Afficher un décompte de temps restant
    Par carmen256 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 23/04/2006, 23h27

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