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 :

redonner comportement CSS après click sur button radio


Sujet :

JavaScript

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    685
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 685
    Points : 132
    Points
    132
    Par défaut redonner comportement CSS après click sur button radio
    Bonjour,

    Un peu difficile à expliquer, j'ai un codepen

    Le survol du lien "texte libre" affiche un micro-formulaire dans p#texte.
    Si le pointeur quitte p#texte le bloc disparait
    C'est fait en CSS.

    Le javascript fait que si le deuxième choix du formulaire est coché p#texte reste toujours en display clock

    Ce que je n'arrive pas à faire.
    Si le premier choix du formulaire est re-coché, on revient au comportement CSS initial, c'est à dire que p#texte disparait quand ni lui ni "texte libre" n'est survolé par le pointeur.

    Pour résumer :
    Deuxième coché : display: block
    Retour premier choix qui est choix par défaut : on reste en display block mais on passe en display none quand le pointer ne survole plus "texte libre" ou p#texte.

    Merci d'avance pour votre aide.

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 409
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 409
    Points : 15 778
    Points
    15 778
    Par défaut
    pour faire ça, vous devez aussi écouter les modifications de l'autre bouton radio pour changer d'état quand il est sélectionné :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    const nose = document.getElementById('nose');
    nose.addEventListener('change', e => {
    	nose["parentNode"]["style"]["display"] = "";
    });
     
    const netf = document.getElementById('netf');
    netf.addEventListener('change', e => {
    	netf["parentNode"]["style"]["display"] = "block";
    });

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    685
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 685
    Points : 132
    Points
    132
    Par défaut
    Bonjour mathieu,

    Cela marche nickel, j'ai mis le codepen à jour.

    MERCI.

    J'ignorais que l'on peut par JS affecter une valeur vide ("") au display, sachant que cette valeur n'existe pas en CSS.

    Avant de cocher résolu, deux questions sans grande importance :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    nose["parentNode"]["style"]["display"] = ""
    Pourquoi utilises-tu des guillemets doubles alors que les simples suffisent ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    nose['parentNode']['style']['display'] = ''
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    p#texte {display: inline-block; border: 1px solid green}
    Pourquoi ce bloc occupe-t-il toute la largeur du parent ?
    Sauf erreur avec inline-block la largeur est déterminée par le contenu, non ?

  4. #4
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 409
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 409
    Points : 15 778
    Points
    15 778
    Par défaut
    Citation Envoyé par boteha Voir le message
    Pourquoi utilises-tu des guillemets doubles alors que les simples suffisent ?
    c'est juste une question d'esthétique et d'habitude.
    en javascript il y a aussi le caractère ` qui permet d'utiliser des variables à l'intérieur :
    https://developer.mozilla.org/fr/doc...plate_literals

    Citation Envoyé par boteha Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    p#texte {display: inline-block; border: 1px solid green}
    Pourquoi ce bloc occupe-t-il toute la largeur du parent ?
    Sauf erreur avec inline-block la largeur est déterminée par le contenu, non ?
    c'est plutot question de css donc il vaut mieux créer une nouvelle discussion.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    685
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 685
    Points : 132
    Points
    132
    Par défaut
    Merci pour tes précisions.

    En JS, le guillemet double est-il exactement équivalent au guillemet simple ?

    En PHP que je connais mieux il y a une différence :
    " va chercher les variables éventuelles (comme ` en JS si j'ai compris).
    ' ne va rien chercher et type le contenu comme une string
    C'est plus propre et du gagnes un milliardième de seconde à ne pas utiliser " à la place de '.

    Pour le display:inline-block je me demande si ce n'est pas un bug du codepen.

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 16/05/2008, 11h44
  2. [MySQL] Affichage de données après click sur liste déroulante
    Par leloup84 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 27/01/2006, 12h08
  3. [jTabbedPane] action apres click sur onglet
    Par tony_big_guy dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 01/12/2005, 23h29
  4. déclenchement d'un message box après click sur touche entrée
    Par new_wave dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 09/11/2005, 09h15
  5. Réponses: 2
    Dernier message: 26/07/2005, 15h35

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