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 :

setInterval qui ralenti lors d'un changement d'onglet


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2015
    Messages : 45
    Points : 38
    Points
    38
    Par défaut setInterval qui ralenti lors d'un changement d'onglet
    Bonjour,

    Je suis sur une application web multi-joueur et je dois faire certaines actions apres un certain temps qui doit être le même sur toute les machines des utilisateur.

    - Le problème ?

    Lorque je test sur deux navigateur différents avec l'onglet de l'appli ouvert le compte à rebours est identique sur les deux navigateur, le problème est quand sur l'un des navigateurs j'ouvre par exemple un deuxième onglet alors là le setInterval de mon appli sur ce navigateur prend totalement du retard par rapport aux autres, mais vraiment beaucoup de retard, et le retard prit augmente en fonction du temps ou je ne suis pas sur l'onglet de mon appli. Ce qui me pose un réelle problème, comment le résoudre ?

    Je pourrais faire le setInterval côté serveur (nodeJS) comme ça tous les clients auront le message au même moment cependant ça ne change pas le fait que le compteur côté client sera totalement désordonné comparé à la réalité et que je pense que ça fait trop lourd pour le serveur de gérer tous ces setInterval en même temps (1 par salle), il peut y avoir beaucoup de salle.

    Merci pour toute vos futures aides !


    Nous avons ici, un premier setInterval qui est compte_a_rebour qui quand il a fini lance le second qui est chrono.

    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
    24
    25
    26
    27
    28
    29
    /* ------------------------------------------------
    * COMPTE A REBOUR POUR L'AFFICHAGE DE LA LETTRE
    * ------------------------------------------------ */
    compte_a_rebour = function(i, obj, txt_final){
    	compte_a_rebour = setInterval(function(){
    		if (i >= 1){
    			$(obj).html('<b>'+ i +'</b>'); i--;
    		}
    		else{	
    			clearInterval(compte_a_rebour);
    			$(obj).html('<b>'+ txt_final +'</b>');
    			chrono(100, $('#chrono'));
    		}
    	}, 1000);
    }
    /* -----------------------------------------
     * COMPTE A REBOUR POUR LA FIN DE LA MANCHE
     * ----------------------------------------- */
    chrono = function(i, obj){
    	chrono = setInterval(function(){
    		if (i > 0) {
    			$(obj).html(i); i--;
    		}
    		else{
    			$(obj).html('');
    			clearInterval(chrono);
    		}
    	}, 1000)
    }

  2. #2
    Membre chevronné

    Homme Profil pro
    développeur
    Inscrit en
    Octobre 2013
    Messages
    1 576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : développeur

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 576
    Points : 1 989
    Points
    1 989
    Par défaut
    Bonjour, regarde
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    setCorrectingInterval()
    .

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2015
    Messages : 45
    Points : 38
    Points
    38
    Par défaut
    Ah ! Merci t'es un champion

    Bonne après-midi

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 8
    Dernier message: 18/11/2014, 18h44
  2. Lors d'un changement d'onglet la couleur de background ne change pas
    Par alaninho dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 06/11/2013, 14h58
  3. Timer qui accelère lors d'un changement d'onglet.
    Par themoye dans le forum Général JavaScript
    Réponses: 25
    Dernier message: 09/11/2011, 18h37
  4. Un processus qui ralenti lors de son second appel
    Par maccormick dans le forum Général Java
    Réponses: 17
    Dernier message: 29/06/2011, 12h30
  5. Réponses: 4
    Dernier message: 23/04/2007, 16h47

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