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 :

disabled de plusieurs checkbox quand une checkbox est cochée


Sujet :

JavaScript

  1. #1
    Membre du Club
    Femme Profil pro
    ingénieur d'étude en bioinformatique
    Inscrit en
    Février 2011
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : ingénieur d'étude en bioinformatique
    Secteur : Service public

    Informations forums :
    Inscription : Février 2011
    Messages : 45
    Points : 43
    Points
    43
    Par défaut disabled de plusieurs checkbox quand une checkbox est cochée
    Bonjour,
    Comme le titre l'indique, j'ai un problème quand je veux rendre "disabled" plusieurs checkbox apres avec cocher une autre checkbox.
    Je vous montre le code que j'ai écrit pour cela :

    Le code 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
    16
    17
    18
     
    switch (true)
    {
    	case (document.form.chr0.checked):
    		document.form.chr1.disabled=true;
    		document.form.chr2.disabled=true;
    		document.form.chr3.disabled=true;
    		document.form.chr4.disabled=true;
    		document.form.chr5.disabled=true;
    		 break;
     
    	default: 
    		document.form.chr1.disabled=false;
    		document.form.chr2.disabled=false;
    		document.form.chr3.disabled=false;
    		document.form.chr4.disabled=false;
    		document.form.chr5.disabled=false;       
    }
    Le formulaire HTML :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <form method="post" action="recherche_detaillee.php" name="form">
    	<input type="text" name="texte">
    	<br>
    	<h3>&bull; Choix du chromosome :</h3>
    	<input type= "checkbox" name="chr0" value="0" > Indifférent
    	<input type= "checkbox" name="chr1" value="1" > 1
    	<input type= "checkbox" name="chr2" value="2" > 2
    	<input type= "checkbox" name="chr3" value="3" > 3
    	<input type= "checkbox" name="chr4" value="4" > mitochondrial
    	<input type= "checkbox" name="chr5" value="5" > mating type region
    Si vous avez une autre solution, ce que je cherche a faire c'est :
    - quand la checkbox "Indifférent" (chr0) est cochée, les autres sont grisés, l'utilisateur ne peut pas les cocher, de plus, cela décoche les autres checkbox
    - quand la checkbox "Indifférent" est décochée, on peut séléctionner ce qu'on veut

    Si vous avez une solution,
    Merci beaucoup,

  2. #2
    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
    N'utilise pas form comme nom de ton formulaire ! C'est déjà un nom de propriété JavaScript.

  3. #3
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonsoir,

    +1 Bovino
    switch (true)
    et un nom de variable "true".

    A+.

  4. #4
    Membre du Club
    Femme Profil pro
    ingénieur d'étude en bioinformatique
    Inscrit en
    Février 2011
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : ingénieur d'étude en bioinformatique
    Secteur : Service public

    Informations forums :
    Inscription : Février 2011
    Messages : 45
    Points : 43
    Points
    43
    Par défaut
    J'ai modifié mon code comme ceci, avec ce que vous m'avez indiqué :
    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
     
    switch (document.form1.chr0.checked=true)
    {
    	case (document.form1.chr0.checked):
    		document.form1.chr1.disabled=true;
    		document.form1.chr2.disabled=true;
    		document.form1.chr3.disabled=true;
    		document.form1.chr4.disabled=true;
    		document.form1.chr5.disabled=true;
    		 break;
     
    	default: 
    		document.form1.chr1.disabled=false;
    		document.form1.chr2.disabled=false;
    		document.form1.chr3.disabled=false;
    		document.form1.chr4.disabled=false;
    		document.form1.chr5.disabled=false;       
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    <form method="post" action="recherche_detaillee.php" name="form1">
    	<input type="text" name="texte">
    	<br>
    	<h3>&bull; Choix du chromosome :</h3>
    	<input type= "checkbox" name="chr0" value="0" > Indifférent
    	<input type= "checkbox" name="chr1" value="1" > 1
    	<input type= "checkbox" name="chr2" value="2" > 2
    	<input type= "checkbox" name="chr3" value="3" > 3
    	<input type= "checkbox" name="chr4" value="4" > mitochondrial
    	<input type= "checkbox" name="chr5" value="5" > mating type region
    Mais cela ne marche toujours pas. Est ce que j'ai un problème de syntaxe dans mes input ? ou dans mon JS ?

  5. #5
    Membre éclairé Avatar de Ceddoc
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Janvier 2009
    Messages : 493
    Points : 698
    Points
    698
    Par défaut
    Essaye ça :

    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
     
    switch (document.form1.chr0.checked)
    {
    	case (true):
    		document.form1.chr1.disabled=true;
    		document.form1.chr2.disabled=true;
    		document.form1.chr3.disabled=true;
    		document.form1.chr4.disabled=true;
    		document.form1.chr5.disabled=true;
    		 break;
     
    	default: 
    		document.form1.chr1.disabled=false;
    		document.form1.chr2.disabled=false;
    		document.form1.chr3.disabled=false;
    		document.form1.chr4.disabled=false;
    		document.form1.chr5.disabled=false;       
    }

  6. #6
    Expert confirmé
    Avatar de RomainVALERI
    Homme Profil pro
    POOête
    Inscrit en
    Avril 2008
    Messages
    2 652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : POOête

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Points : 4 164
    Points
    4 164
    Par défaut
    La refactorisation me démangeait trop...
    ...pas pu m'en empêcher.

    Tu peux remplacer l'extrait de JS cité par :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var inputs = document.form1.getElementsByTagName("INPUT");
    for (var i = 0; i < inputs.length; ++i)
       if ((inputs[i].type == "checkbox") && (inputs[i].id != "check0"))
          inputs[i].disabled = document.getElementById("check0").checked;
    ...en pensant juste à coller un id="check0" au checkbox spécifique qui est le critère de ton test pour y accéder plus facilement ^^

  7. #7
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonsoir,

    Pourquoi ne pas utiliser simplement un if else vu que tu ne testes que si c'est à true ou false?

    A+.

  8. #8
    Expert confirmé
    Avatar de RomainVALERI
    Homme Profil pro
    POOête
    Inscrit en
    Avril 2008
    Messages
    2 652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : POOête

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Points : 4 164
    Points
    4 164
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Bonsoir,

    Pourquoi ne pas utiliser simplement un if else vu que tu ne testes que si c'est à true ou false?

    A+.
    Citation Envoyé par RomainVALERI Voir le message
    ...
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var inputs = document.form1.getElementsByTagName("INPUT");
    for (var i = 0; i < inputs.length; ++i)
       if ((inputs[i].type == "checkbox") && (inputs[i].id != "check0"))
          inputs[i].disabled = document.getElementById("check0").checked;
    ...
    ?

  9. #9
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Citation Envoyé par RomainVALERI Voir le message
    ?


Discussions similaires

  1. Réponses: 3
    Dernier message: 26/04/2015, 15h06
  2. [XL-2003] Bloquer l'utilisation d'une checkbox si une autre est cochée
    Par xiungung dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 10/06/2009, 15h36
  3. Griser Checkbox quand une autre est séléctionnée
    Par FleuVounet dans le forum Composants
    Réponses: 1
    Dernier message: 15/04/2009, 12h32
  4. Décocher une case quand une autre est cochée
    Par petitange_lili dans le forum Qt
    Réponses: 14
    Dernier message: 27/06/2008, 19h01
  5. Décocher une checkbox si une autre est coché
    Par Sieldev dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 10/07/2007, 13h11

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