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 :

desactiver bouton radio


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2006
    Messages : 122
    Points : 65
    Points
    65
    Par défaut desactiver bouton radio
    Bonjour,
    J'aimerai desactiver des boutons radio si on a cocher un checkbox.
    J'ai réussi à faire l'inverse, c'est à dire à desactiver des cases à cocher en fonction du bouton radio coché mais là je n'y arrive pas

    J'ai essayé comme ça, mais ça ne marche pas


    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
     
    function accesradio()
    	{
    		var coche;
    		for (i=0; i<document.formulaire.abstention.length; i++) 
    		{
    			if (document.formulaire.abstention[i].checked)
    			{
    				coche == true;
    			}
    		   else
    			{
    				coche == false;
    			}
    		}
     
    		if (coche == false)
    		{
    			document.forms["formulaire"].elements["abstention1"].disabled=true;
    		}
    		else
    		{
    			document.forms["formulaire"].elements["abstention1"].disabled=false;
    		}
    	}
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <tr>
    			<td><input type="checkbox" name="abstention" value="abstention">Abstention</td>
    			<td align="center"><input type="radio" name="abstention1" value="accepté" onClick="accesradio()">
    			<td align="center"><input type="radio" name="abstention1" value="modifié" onClick="accesradio()">
    			<td align="center"><input type="radio" name="abstention1" value="ajouté" onClick="accesradio()">
    			<td align="center"><input type="radio" name="abstention1" value="contre indiqué" onClick="accesradio()">		
    		</tr>
    Je vous remercie d'avance

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 397
    Points : 430
    Points
    430
    Par défaut
    Pour désactiver tes boutons radios, il va falloir travailler sur la checkbox et non sur les boutons radios, ta fonction doit être déclenchée sur une évènement placé sur la checkbox.

    Ensuite, vu que tu n'as qu'une seule checkbox, où est l'interêt d'utiliser un index pour faire tourner une boucle, ce n'est pas logique.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    if(document.getElementsByName('abstention').checked)
    {
       document.forms["formulaire"].elements["abstention1"].disabled=false;
    }
    else
    {
       document.forms["formulaire"].elements["abstention1"].disabled=true;
    }
    Il te faut quelque chose qui ressemble à ca.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2006
    Messages : 122
    Points : 65
    Points
    65
    Par défaut
    J'ai pas fait le boucle au départ, et comme ça marchait pas, j'ai essayé. Mais là ça ne fonctionne toujours pas avec

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    function accesradio()
    	{
    		if(document.getElementsByName('abstention').checked)
    		{
    		   document.forms["formulaire"].elements["abstention1"].disabled=false;
    		}
    		else
    		{
    		   document.forms["formulaire"].elements["abstention1"].disabled=true;
    		}
    	}
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <td><input type="checkbox" name="abstention" value="abstention" onClick="accesradio()">Abstention</td>
    			<td align="center"><input type="radio" name="abstention1" value="accepté">
    			<td align="center"><input type="radio" name="abstention1" value="modifié">
    			<td align="center"><input type="radio" name="abstention1" value="ajouté">
    			<td align="center"><input type="radio" name="abstention1" value="contre indiqué">

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 397
    Points : 430
    Points
    430
    Par défaut
    C'est déjà plus logique, mais il doit me manquer un bout de code pour identifier la checkbox cochée...

    Quelqu'un de plus confirmé que moi viendra t'aider. Bon courage.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2006
    Messages : 122
    Points : 65
    Points
    65
    Par défaut
    Comme je n'ai plus d'autres aides, et qu je n'y arrive pas en tournant le code, j'ai trouvé celui-ci sur en cherchant un peu à coté, mais il ne marche pas non plus, Au fait, il ne désactive que le premier bouton radio, et pas les restes.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function GereControle(Controleur, Controle, Masquer) 
    	{
    var objControleur = document.getElementById(Controleur);
    var objControle = document.getElementById(Controle);
    	if (Masquer=='1')
    		objControle.style.visibility=(objControleur.checked==true)?'visible':'hidden';
    	else
    		objControle.disabled=(objControleur.checked==true)?false:true;
    	return true;
    	}
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <table>
    <tr>	
    			<td><input type="checkbox" id="chkb_2" onClick="GereControle('chkb_2', 'radio1', '0');" name="abstention" value="abstention">&nbsp;<label for="chkb_1">Abstention</label></td>
    			<td align="center"><input type="radio" id="radio1" name="abstention1" value="accepté">
    			<td align="center"><input type="radio" id="radio1" name="abstention1" value="modifié">
    			<td align="center"><input type="radio" id="radio1" name="abstention1" value="ajouté">
    			<td align="center"><input type="radio" id="radio1" name="abstention1" value="contre indiqué">	
    		</tr>
    </table>
    je ne sais pas si on ne peut pas mettre le même id pour les bouton, mais ce n'est pas logique.

    Si quelqu'un trouve la faille.

    Merciii

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 397
    Points : 430
    Points
    430
    Par défaut
    Interdiction d'avoir plusieurs fois le même id !!!!!!!!!!!

    Remets des noms d'ids différents à tes boutons radios et passe par :

    getElementsByName avec abstention1 passé en paramètre.

    Grace à ca tu vas obtenir un tableau contenant tes boutons radio et tu fais une boucle for pour desactiver tout tes boutons radios.

  7. #7
    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
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(document.getElementsByName('abstention').checked)
    getElementsByName, comme le "s" l'indique, renvoie un tableau d'éléments, il faut ensuite indiquer lequel tu veux utiliser...

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 397
    Points : 430
    Points
    430
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    function GereControle(Controleur, Controle, Masquer) 
    	{
    var objControleur = document.getElementById(Controleur);
    var objControle = document.getElementsByName(Controle);
     
    for(i=0;i<objControle.length;i++)
    {
        if (Masquer=='1')
    		objControle[i].style.visibility=(objControleur.checked==true)?'visible':'hidden';
    	else
    		objControle[i].disabled=(objControleur.checked==true)?false:true;
    	return true;
    	}
    }
    Ca doit donner quelque chose qui peut ressembler à ça.

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2006
    Messages : 122
    Points : 65
    Points
    65
    Par défaut
    Merci, c'est ce que j'ai fait et ça donne le même résultat, il n'y a que le premier bouton radio qui est desactivé.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    function GereControle(Controleur, Controle, Masquer) 
    	{
    		var objControleur = document.getElementById(Controleur);
    		var objControle = document.getElementsByName(Controle);
     
    		for(i=0;i<objControle.length;i++)
    		{
    		    if (Masquer=='1')
    				objControle[i].style.visibility=(objControleur.checked==true)?'visible':'hidden';
    			else
    				objControle[i].disabled=(objControleur.checked==true)?false:true;
    			return true;
    		}
    	}
    J'ai enlevé les id des radio vu qu'ici ils ne servent pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <table>
    <tr>	
    			<td><input type="checkbox" id="chkb_2" onClick="GereControle('chkb_2', 'abstention1', '0');" name="abstention" value="abstention">&nbsp;<label for="chkb_1">Abstention</label></td>
    			<td align="center"><input type="radio" name="abstention1" value="accepté">
    			<td align="center"><input type="radio" name="abstention1" value="modifié">
    			<td align="center"><input type="radio" name="abstention1" value="ajouté">
    			<td align="center"><input type="radio" name="abstention1" value="contre indiqué">	
    		</tr>
    </table>

  10. #10
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 397
    Points : 430
    Points
    430
    Par défaut
    C'est le return true qui bloque ta boucle, puisque des que la fonction trouve un return elle stoppe son execution. Il faut mettre le return true ailleurs, ou alors carrément le supprimer si il n'a aucune utilité...

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2006
    Messages : 122
    Points : 65
    Points
    65
    Par défaut
    Super, ça marche!!!!

    Merci à tous!

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

Discussions similaires

  1. Desactiver un bouton quand un bouton radio est coché
    Par CaNiBaLe dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 01/06/2012, 15h30
  2. recupérer la valeur d'un bouton radio
    Par ericmart dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 19/05/2008, 15h42
  3. Bouton radio activant/desactivant checkbox - adaptation de la FAQ
    Par 12monkeys dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 07/09/2007, 16h38
  4. [CR]liste de boutons radio
    Par inesfonfon dans le forum SAP Crystal Reports
    Réponses: 5
    Dernier message: 16/09/2004, 09h04
  5. Problème de boutons radio
    Par BRAUKRIS dans le forum Composants
    Réponses: 3
    Dernier message: 03/06/2004, 02h41

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