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 :

clearInterval ne fonctionne pas


Sujet :

JavaScript

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Par défaut clearInterval ne fonctionne pas
    Bonjour et merci d'avance pour votre aide.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    function setTimepicker(){..}
     
    swtich (index) {
    case 1:
    setInterval ('setTimepicker()', 5000);
    break;
    case 2:
    clearInterval('setTimepicker()')
    break;}

    }

    J'ai aussi essayé:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    function setTimepicker(){..}
     
    function setInterval_Timepicker(){
    	interval = setInterval('setTimepicker()', 5000);
    	}
     
    function clearInterval_Timepicker(){clearInterval(interval); alert('stop');}
    Et j'appelle ces fonctions depuis mon switch.

    setTimePicker() se lance, mais ne s'arrête jamais.

    Encore merci,

  2. #2
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut
    Salut as tu essayé ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     
    function setInterval_Timepicker(){
    	var interval = setInterval('clearInterval_Timepicker()', 5000);
    	}
     
    function clearInterval_Timepicker(){clearInterval(interval); alert('stop');}
    Pas testé, mais l'idée est là bonne soirée.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    function setInterval_Timepicker(){
    	var interval = setInterval('clearInterval_Timepicker()', 5000);
    	}
     
    function clearInterval_Timepicker(){clearInterval(interval); alert('stop');}
    J'ai n'est peut être pas été clair dans l'énoncé du probléme.
    Mais je dois lancer la fonction setTimepicker() toute les x sec.
    Et non pas le clearInterval, comme indiqué dans ton code.
    Merci tout de même de t'être pencher sur mon cas.

  4. #4
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684
    Par défaut
    déclare
    en global...

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Par défaut
    Merci pour ta réponse, mais le probléme reste inchangé.
    J'ai bien l'alert (interval)
    Ensuite l'alert(stop), mais alert(interval) continue.
    Voici en gros la structure de mon code, deux fichier JS en externe.

    Dans un fichier JS
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    setTimepicker(){alert('internval);}
     
     
    function setInterval_Timepicker(){
    	interval = setInterval('setTimepicker()', 5000);
    }
     
    function clearInterval_Timepicker(){clearInterval(interval); alert('stop');}

    Et celui-ci dans un autre fichier JS
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    swtich (index) {
    case 1:
    setInterval_Timepicker()
    break;
    case 2:
    clearInterval_Timepicker()
    break;}

  6. #6
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684
    Par défaut
    toujours pas clair... on ne sait pas quand tu appelles l'une ou l'autre fonction et je te disais simplement que tu ne pouvais pas arrêter un timer depuis une fonction si tu ne l'avais pas déclaré en global;

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Par défaut
    setTimepicker(){alert('internval);}
    Une fonction qui initialise un timepicker, cette fonction se trouve dans un fichier appellé class_uiQuery.js. cette fonction doit être relancé toute les minutes.Ce fichier contient aussi mon setInterval et mon clearInterval.
    J'ai délclarer ma variable interval dans ce même fichier en global comme tu me la préconisé.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $(document).ready(function() {
    interval = '';
    }
    Mon swtich case quant à lui gére un wizard pour une réservation.
    ces fonction se trouve dans un autre fichier, class_wizard.js.
    //Date de livraison
    au case 1: j'appelle la fonction setInterval_Timepicker()
    qui va lancé toute les minutes ma fonction setTimepicker()
    //Destination du colis
    au case 2: plus besoin du setTimepicker, j'arrete donc avec mon clearInterval.

    J'aurais publié le code complet, mais le projet étant trés avancé.
    Difficile de tout publier.

    Les fonctions setInterval et clearInterval se lance bien, car j'obtient bien mes alert, mais le setInterval ne s'arrête pas pour autant.

  8. #8
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    Y'a un problème d'inter action entre tes scripts car le deuxième bloc de code de ton premier message fonctionne correctement, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <script type="text/javascript">
    function setTimepicker(){document.getElementById("test").value = parseInt(document.getElementById("test").value)+1;}
     
    function setInterval_Timepicker(){
    	interval = setInterval('setTimepicker()', 1000);
    	}
     
    function clearInterval_Timepicker(){clearInterval(interval);}
     
    </script>
    <input type = "input" id="test" value="1"/>
    <input type = "button" onclick="setInterval_Timepicker()" value="go"/>
    <input type = "button" onclick="clearInterval_Timepicker()" value="stop"/>

  9. #9
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684
    Par défaut
    à condition de faire un clearInterval aussi en appelant setInterval_Timepicker()...

  10. #10
    Membre Expert
    Avatar de Eric2a
    Homme Profil pro
    Technicien
    Inscrit en
    Septembre 2005
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Technicien

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 225
    Par défaut
    Salut,

    Je pense que le mieux est d'utiliser un petit objet.

    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
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    		<title>Test</title>
    		<script type="text/javascript">//<![CDATA[
     
    			function setTimepicker(){
    				alert('interval');
    			}
     
    			// Initialisation de l'objet timePicker
    			var timePicker=(function(f,d){
    				var interval,func,delay;
     
    				if(typeof f=='function'&& d>0){
    					func=f;
    					delay=d;
    				}
     
    				return{
    					_setInterval:function(){
    						if(func && delay && !interval)interval=setInterval(func,delay);
    					},
    					_clearInterval:function(){
    						interval && clearInterval(interval);
    						interval=null;
    					}
    				}
    			})(	setTimepicker,	// Réference de la fonction appelée à intervalles réguliers
    				3000		// delai en millisecondes
    			);
    			//]]>
    		</script>
    	</head>
    	<body>
    		<button onclick="timePicker._setInterval()">Start</button>
    		<button onclick="timePicker._clearInterval()">Stop</button>
    	</body>
    </html>

  11. #11
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Par défaut
    Citation Envoyé par Eric2a Voir le message
    Salut,

    Je pense que le mieux est d'utiliser un petit objet.
    Merci Eric2a pour la solution, elle fonctionne.
    Mais tu n'y vois aucun inconveniant à m'expliquer pas à pas ton code, histoire d'apprendre un peu plus ?

    Et merci à tout les autres de vous êtres penchez sur mon code.

Discussions similaires

  1. Réponses: 6
    Dernier message: 27/01/2004, 11h14
  2. [FP]Writeln ne fonctionne pas !
    Par néo333 dans le forum Turbo Pascal
    Réponses: 4
    Dernier message: 01/11/2003, 23h47
  3. UNION qui ne fonctionne pas
    Par r-zo dans le forum Langage SQL
    Réponses: 7
    Dernier message: 21/07/2003, 10h04
  4. Un Hint sur un PopupMenu ne fonctionne pas !!??
    Par momox dans le forum C++Builder
    Réponses: 6
    Dernier message: 26/05/2003, 16h48
  5. ca ne fonctionne pas (generateur auto-incrémentant)
    Par tripper.dim dans le forum SQL
    Réponses: 7
    Dernier message: 26/11/2002, 00h10

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