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

HTML Discussion :

Input radio fonctionnant mal


Sujet :

HTML

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mai 2011
    Messages : 7
    Par défaut Input radio fonctionnant mal
    Bonjour, je ne sais pas trop si je dois poster ici ou dans la section javascript vu que je ne sait pas quelle partie de mon code pose probleme
    Je cherche a faire un formulaire html différent selon la valeur de l'imput radio le problème est que le premier formulaire s'affiche toujours et les deux autres s'affiche en dessous.
    Pour faire le changement j'utilise une fonction javascript je vais vous mettre les codes html et js qui me pose problème si quelqu'un a une idée de ce qui bloque.
    voici la partie formulaire de mon html
    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
    <form method="post"> 
    Type de connexion: 
    <label><input id="typeLogPwd" type="radio" name="typeLogin" value="LogPwd" onchange="afficherLogPwd();"/> LogPwd </label> 
    <label><input id="typeLogNumSecu" type="radio" name="typeLogin" value="LogNumSecu" onchange="afficherLogNumSecu();"/> LogNumSecu </label> 
    <label><input id="typeLog" type="radio" name="typeLogin" value="Log" onchange="afficherLog();"/> Log </label> 
    <div id="LogPwd" style="display: none;"> 
    <table> 
    <tr><td>Login: </td><td colspan="2"><input type="text" name="loginLogPwd" size="9" /></td></tr> 
    <tr><td>pass: </td><td><input type="password" name="pass"/></td></tr>	
    </table> 
    </div> 
    <div id="LogNumSecu" style="display: none;"> 
    <table> 
    <tr><td>Login: </td><td colspan="2"><input type="text" name="loginLogNumSecu" size="9" /></td></tr> 
    <tr><td>Num Secu: </td><td><input type="password" name="pass"/></td></tr> 
    </table> 
    </div> 
    <div id="Log" style="display: none;"> 
    <table> 
    <tr><td>Login: </td><td colspan="2"><input type="text" name="loginLog" size="9" /></td></tr>	
    </table> 
    </div> 
    <input type="submit" value="Connexion" /> 
    </form>
    et le js
    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
    function afficherLogPwd() { 
    document.getElementById('LogPwd').style.display = "block"; 
    document.getElementById('LogNumSecu').style.display = "none"; 
    document.getElementById('Log').style.display = "none";	
    } 
    function afficherLogNumSecu() { 
    document.getElementById('LogPwd').style.display = "none"; 
    document.getElementById('LogNumSecu').style.display = "block"; 
    document.getElementById('Log').style.display = "none"; 
    } 
    function afficherLog() { 
    document.getElementById('LogPwd').style.display = "none"; 
    document.getElementById('LogNumSecu').style.display = "none"; 
    document.getElementById('Log').style.display = "block"; 
    }

  2. #2
    Membre chevronné Avatar de Nheo_
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    323
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 323
    Par défaut
    Bonjour,

    Je viens de tester ton code et tout marche bien : je n'ai bien qu'un seul div en fonction du radio. (Firefox 4).

    Sous quel navigateur as tu testé ? Peux tu testé sur plusieurs ?

    Et n'oublie pas : ^^. Sinon très difficile de lire ton code.

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mai 2011
    Messages : 7
    Par défaut
    Désolé pour les balises petit oubli de ma part.
    En effet le code marche parfaitement seul (j'avait supprimer une partie du code qui n'avait rien a voir apperement le probleme vient du table qui faisait planter)
    En tout cas merci quand meme car je n'ai pas eu l'idée de le tester tel quel!!!

  4. #4
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mai 2011
    Messages : 7
    Par défaut
    En fait le problème persiste mais seulement avec IE (et oui malheureusement c'est un obligation d'utiliser IE). En fait j'ai un peu plus cerner le problème sous IE après avoir cliqué sur l'input radio il faut refaire un click (peu importe ou) pour que le formulaire change (comme si il fallait confirmer le changement) Ce problème n'est présent ni sur chrome ni sur firefox et je n'arrive pas a voir d'ou cela vient.

  5. #5
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonjour,
    ce n'est pas une bonne idée que d'utiliser l'événement onchange sur des radios boutons, d'autant que IE ne considère le changement que lorsque l'élément à perdu le focus.
    Il faut voir que lorsqu'un radio change cela entraîne le changement d'état des autres donc possible "emmêlage" de pinceau...

    Il est dans ce cas plus judicieux de passer par l'événement onclick, sachant que quand on clique sur un radio bouton c'est pour le sélectionner.

    Tu peux également fusionner tes fonctions en une seule
    exemple
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function affiche( obj){
      var tId = ['LogPwd', 'LogNumSecu', 'Log']; // les IDs a afficher/masquer
      for( var i in tId){
        document.getElementById( tId[i]).style.display = tId[i] == obj.value ? 'block' : 'none';
      }
    }
    avec un appel
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <input id="typeLogPwd" type="radio" name="typeLogin" value="LogPwd" onclick="affiche(this);" /> LogPwd </label>

Discussions similaires

  1. Formulaire AJAX, élément input radio ne fonctionne pas
    Par benflodu69 dans le forum Langage
    Réponses: 4
    Dernier message: 25/05/2014, 23h02
  2. Input radio : checked="checked" ne fonctionne pas.
    Par Bash01 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 03/08/2010, 10h03
  3. Taille d'un input radio
    Par messa dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 24/08/2006, 13h58
  4. Activer boutons checkbox SEULEMENT si un input radio est coché
    Par bobic dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 28/04/2006, 14h05
  5. un DELETE qui fonctionne mal
    Par HULK dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 06/02/2006, 18h59

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