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 :

Activer boutons checkbox SEULEMENT si un input radio est coché


Sujet :

JavaScript

  1. #1
    Membre régulier
    Inscrit en
    Mai 2005
    Messages
    364
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 364
    Points : 120
    Points
    120
    Par défaut Activer boutons checkbox SEULEMENT si un input radio est coché
    bjour,

    J'aimerais faire un petit formulaire dans lequel divers options sont proposée avec des boutons radios.

    Dans le cas, où un bouton radio est choisi (le dernier par exemple), cela active des checkbox.

    Mon actuel est le suivant:

    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
     
    <script type='text/javascript'>
     
    function disableInput(idInput, valeur)
    {
    var input = document.getElementById(idInput);
    input.disabled = valeur;
    if (valeur) {
    input.style.background = "#CCC";
    BSajoute(idInput);
    } else {
    input.style.background = "#FFF";
    BSsuppr(idInput);
    }
    }
     
    function enableInput(idInput, valeur)
    {
    var input = document.getElementById(idInput);
    input.enable = valeur;
    if (valeur) {
    input.style.background = "#FFF";
    BSsuppr(idInput);
    } else {
    input.style.background = "#CCC";
    BSajoute(idInput);
    }
    }
    </script>
     
    <fieldset>
    <legend>Activer/désactiver un champ en cliquant sur une case à cocher</legend>
    <input name="active" id="idactive" onclick="disableInput('ida', this.checked);" type="checkbox" />
     
    <input name="active" id="idactive" onclick="disableInput('ida', this.checked);" type="radio" />
    <input name="active" id="idactive" onclick="enableInput('ida', this.checked);" type="radio" />
     
    <input name="a" id="ida" type="checkbox" />
    </fieldset>
    Dans mon exemple, si on coche le premier checkbox, cela active (ou désactive) la seconde checkbox.
    Mais, j'aimerais faire la même chose avec un bouton radio. Ainsi, quand on sélectionne le premier bouton radio, cela désative la checbox, et quand on choisi la seconde, cela ne fait rien, alors quue j'aimerai que ça la rendre active....

    J'ai essayé diverses choses trouvées sur le net que j'ai essayé d'adapter mais je n'y arrive pas...

    merci de votre aide

  2. #2
    Membre confirmé Avatar de supermanu
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    330
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 330
    Points : 452
    Points
    452
    Par défaut
    Si j'ai bien compris, tu veux que lorsque tu clique sur un bouton radio tu puisse cocher la checkbox et sinon elle doit être grisée ?

    Tout d'abord, le name de la première checkbox ne doit pas être "active".

    Puis tu peux faire une fonction de ce style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    function activeDesactive(radio) {
            objForm = document.forms[0];
     
            if(radio[0].checked) {
                objForm.elements["a"].disabled = false;
     
            }
            else {
                objForm.elements["a"].disabled = true;
     
            }
        }
    et pour les boutons radio, tu mets :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    onclick="activeDesactive(this.form.active);"
    Pensez au tag
    Mon blog Tutoriels et Astuces en Java : http://emmanuelpierre.free.fr/blog/index.php?

  3. #3
    Membre régulier
    Inscrit en
    Mai 2005
    Messages
    364
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 364
    Points : 120
    Points
    120
    Par défaut
    oui, c'est à fait cela que je recherche !

    J'ai donc fait ceci comme 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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    <html>
    <head>
    <script type='text/javascript'>
     
    function activeDesactive(radio) {
            objForm = document.forms[0];
     
            if(radio[0].checked) {
                objForm.elements["a"].disabled = false;
     
            }
            else {
                objForm.elements["a"].disabled = true;
     
            }
        }
    </script>
    </head>
    <body>
    <form name=form>
     
     
    <input name="essai" id="idactive" onclick="activeDesactive(this.form.active);" type="radio" />
    <input name="essai" " type="radio" />
     
    <input name="a" id="ida" type="checkbox" />
     
    </form>
    </body>
    </html>
    le but est donc que quand l'utilisateur choisisse le premier bouton radio, la check box soit dispo, et s'il clique sur l'autre bouton radio, elle soit décochée.

    Mais j'ai une erreur avec les indices (le 0)
    j'ai donc du mal faire un truc....
    j'ai essayé en mettant directement son nom (je ne sais pas si cela fonctionne en JS) mais j'ai tjs un "xxxxx" is undefined....

  4. #4
    Membre confirmé Avatar de supermanu
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    330
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 330
    Points : 452
    Points
    452
    Par défaut
    Il faut que tu mettes
    dans le onclick car tes boutons radio s'appellent "essai"

    et fais un copier/coller du onClick dans le second bouton radio. (d'ailleurs tu as une " en trop)
    Sinon pour "débugger" le javascript j'utilise la console javascript de firefox, c'est assez pratique
    Pensez au tag
    Mon blog Tutoriels et Astuces en Java : http://emmanuelpierre.free.fr/blog/index.php?

  5. #5
    Membre régulier
    Inscrit en
    Mai 2005
    Messages
    364
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 364
    Points : 120
    Points
    120
    Par défaut
    ah oui zut!

    j'ai corrigé, IMPECCABLE ! merci à toi !

    Sinon, oui pour Firefox j'en suis un inconditionnel (surtout sous Linux ), mais étant sur un poste du taf sur lequel je ne peux rien installer..... malheureusement......

    Encore merci pour ta rapidité et ton aide !

  6. #6
    Membre confirmé Avatar de supermanu
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    330
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 330
    Points : 452
    Points
    452
    Par défaut
    Ya pas de quoi, penses au tag RESOLU, dans l'onglet Outils de la discussion
    Pensez au tag
    Mon blog Tutoriels et Astuces en Java : http://emmanuelpierre.free.fr/blog/index.php?

  7. #7
    Membre régulier
    Inscrit en
    Mai 2005
    Messages
    364
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 364
    Points : 120
    Points
    120
    Par défaut
    oups, désolé, je n'ai pas eu le tps de metre le tag résolu !

    J'ai fait un rapide test avec tout petit form, cela fctionne nickel, mais pas sur mon vrai formulaire !

    Je vais chercher j'ai du faire une erreur

    edit:

    je viens de supprimer le tag résolu car, j'ai trouvé pourquoi le js ne voulait pas fctionner.

    En fait, il n'accepte pas d'avoir plusieurs checkbox du même nom!
    Malheureusement, je suis obligé d'en avoir plusieurs du meêm nom, car la valeur des ceckbox est récupérées via un script en asp dans une base de donnée, et c'est aussi asp qui me permet de me retransmettre ensuite ces valeurs comme il : var1,var2var3 (ce qui fait que j'en fait ensuite une inclusion dans un IN d'une requête).... Bref, je suis "obligé d'avoir plusieurs checkbox du même nom

    Comment faire pour que le script fonctionne dans ce cas ??

    Je précise que la console débug de Firefox (que j'ai finalement installé car j'ai cracké avec IE) ne me renvoit aucune erreur.

    Merci

  8. #8
    Membre confirmé Avatar de supermanu
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    330
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 330
    Points : 452
    Points
    452
    Par défaut
    Tu peux peut-être mettre des id différents pour tes checkbox ?
    et les récuprérer grâce à document.getElementById('ton_id'); au lieu de objForm.elements["a"]
    Pensez au tag
    Mon blog Tutoriels et Astuces en Java : http://emmanuelpierre.free.fr/blog/index.php?

  9. #9
    Membre régulier
    Inscrit en
    Mai 2005
    Messages
    364
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 364
    Points : 120
    Points
    120
    Par défaut
    j'essaie et te dis le résultat

  10. #10
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    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 681
    Points : 5 221
    Points
    5 221
    Par défaut
    quand on sélectionne le premier bouton radio, cela désative la checbox
    sans regarder le reste, je te le dis: c'est absurde;

    et pourtant, je suis un garçon sympathique et ouvert à toutes expériences javatwistantes!

    bref, pour désactiver une checkbox, il suffit de cliquer dessus;

  11. #11
    Membre régulier
    Inscrit en
    Mai 2005
    Messages
    364
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 364
    Points : 120
    Points
    120
    Par défaut
    c'est nickel !

    merci

    Pour répondre à JavaTwister non cela n'est pas absurde.
    Explication: j'ai un form de ce style:

    boutonradio1
    boutonradio2
    boutonradio3

    Dans le cas du choix3, veuillez spécifier plus présément votre choix:
    checkbox1
    check2
    check3

    Le fait de désactiver la possibilité de cocher les checks permet de mieux faire à l'utilisateur que même s'il coche les check et un des deux premiers boutons radio, seuls les boutons radio seront prix en compte. C'est sur que au niveau du traitement, cela ne change rien !

    cela te parait moins absurde maintenant ???

  12. #12
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    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 681
    Points : 5 221
    Points
    5 221
    Par défaut
    non non, aucune explication ne me convaincra: pour décocher une chekbock, il faut cliquer dessus...

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

Discussions similaires

  1. Cocher un checkbox dès qu'un bouton radio est coché
    Par fabulon46 dans le forum Général JavaScript
    Réponses: 10
    Dernier message: 23/01/2014, 17h18
  2. 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
  3. Vérifier qu'un bouton radio est coché
    Par vince351 dans le forum jQuery
    Réponses: 1
    Dernier message: 11/07/2010, 22h38
  4. Exécuter une action quand un bouton radio est coché
    Par eddycool dans le forum Langage
    Réponses: 8
    Dernier message: 29/05/2009, 10h42
  5. Savoir si un bouton Radio est coché
    Par bullrot dans le forum Langage
    Réponses: 4
    Dernier message: 23/09/2008, 12h30

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