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 :

Souci avec le setInterval sur une balise <button>


Sujet :

JavaScript

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 73
    Par défaut Souci avec le setInterval sur une balise <button>
    Je remarque une différence entre la balise <input> et la balise <button type=‘submit’> que j'utilise pour fermer ma fenêre.

    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
    41
    42
     
     
    <form>
    <button type="submit" onClick="javascript:valider()">
    </form>
     
    <script type="text/javascript" language="javascript">
    var i=0;
    var IsIE=!!document.all,timer;
     
    function valider() 
    {closeModal();
    }
     
    function closeModal()
    {
    	if((!timer)||i==0)
    	{
    		timer=setInterval(timer_dec,1);
    	}
    }
     
    function timer_dec()
    {
    	if(i==0)
    	{
    		clearInterval(timer);
    		calque.style.display='none';
    		self.close();
    	}
    	else
    	{
    		if(IsIE)
    		{calque.filters[0].opacity=i*0.75;}
    		else
    		{calque.style.opacity=(i/100)*0.75;}
    		i = Math.max(i-10,0);
    	}
    	alert(i);
    }
    Du coup, quand j’utilise une balise button à la place de <input>, le fonctionnement n’est pas le même il ne reste pas dans la boucle pour décrémenter la variable ‘i’, c’est quoi la différence/le souci ?

  2. #2
    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 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 658
    Billets dans le blog
    1
    Par défaut
    ça existe ça un button type submit ???

    un input je connais mais pas un bouton ..
    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 !

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 73
    Par défaut
    Si si cela existe

  4. #4
    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 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 658
    Billets dans le blog
    1
    Par défaut
    oui tiens ! c'est w3c compliant ...
    c'est juste encore IE qui se fourvoie
    passe sur un input au lieu d'un button et ça devrait rentrer dans l'ordre
    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 !

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 73
    Par défaut
    Non non sous Firefox cela ne fonctionne pas mieux.

    Je voulais garder un button parce que derrière j'ai une balise span et em me permettant de générer un bouton dynamique (texte dynamique) que je n'arrive pas à réaliser avec une balise input.

    En fait j'ai l'impression que lorsque j'utilise button il va bien une première fois dans ma fonction 'timer_dec' mais par contre il n'y revient pas alors que j'ai défini un setInterval dessus...

  6. #6
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Salut,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <button type="submit" onClick="javascript:valider()">
    Il y a des choses à revoir
    • <button> n'est pas une balise auto fermante, il faut donc un </button>
    • Le type par défaut étant submit, inutile de le rajouter
    • L'événement onclick attendant du code JavaScript, rajouter javascript: est une erreur
    • Lorsque tu fais un submit, ta page se recharge, donc ta fonction ne s'effectue plus

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <button onclick="valider(); return false">Valider</button>
    Devrait mieux fonctionner.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 73
    Par défaut
    Citation Envoyé par Bovino Voir le message
    Salut,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <button type="submit" onClick="javascript:valider()">
    Il y a des choses à revoir
    • <button> n'est pas une balise auto fermante, il faut donc un </button>
    • Le type par défaut étant submit, inutile de le rajouter
    • L'événement onclick attendant du code JavaScript, rajouter javascript: est une erreur
    • Lorsque tu fais un submit, ta page se recharge, donc ta fonction ne s'effectue plus

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <button onclick="valider(); return false">Valider</button>
    Devrait mieux fonctionner.
    Merci pour votre réponse, cela fonctionne à présent.
    1. j'avais pensé à la balise fermante pour le button
    2. je dois rajouter le type sinon cela ne fonctionne pas, par défaut je pense qu'il a le type button plutôt, non?
    3. j'avais aussi enlever le code 'javascript:'
    4. dans le onclick quelle est la différence entre mettre le return false directement dans l'évenement 'onlick' et le mettre dans la fonction 'valider'?

  8. #8
    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 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 658
    Billets dans le blog
    1
    Par défaut
    le return false ne se justifie que si ton bouton est de type submit, il inhibe alors l'action du form
    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 !

  9. #9
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    je dois rajouter le type sinon cela ne fonctionne pas, par défaut je pense qu'il a le type button plutôt, non?
    En fait, le type par défaut est bien submit... sauf pour IE
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

Discussions similaires

  1. Souci avec les paramettre sur une methode ?
    Par panthere noire dans le forum Threads & Processus
    Réponses: 2
    Dernier message: 17/06/2012, 20h23
  2. Requete MySQL avec un Rand sur une table
    Par tom06440 dans le forum Requêtes
    Réponses: 2
    Dernier message: 05/01/2006, 17h37
  3. concaténation sur une balise image
    Par hutchuck dans le forum Langage
    Réponses: 5
    Dernier message: 15/12/2005, 12h49
  4. Formulaire avec liste basée sur une autre table
    Par sabotage dans le forum Langage SQL
    Réponses: 6
    Dernier message: 10/08/2005, 13h43
  5. pb d'insertion avec un SELECT sur une autre table
    Par epeichette dans le forum Requêtes
    Réponses: 3
    Dernier message: 03/01/2005, 22h58

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