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

jQuery Discussion :

Affichage dropdown menu


Sujet :

jQuery

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    175
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2008
    Messages : 175
    Par défaut Affichage dropdown menu
    Cordialement,

    Mon Problème est que quand je clique par exemple sur dropdowm menu 1 et puis dropdown menu 2, dropdowm menu devient inactif.

    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
     
    jQuery(document).ready(function(e) {
      e(".dropdown-toggle").click(function() {
       var t = e(this).parents(".button-dropdown").children(".dropdown- 
       menu").is(":hidden");
      e(".button-dropdown .dropdown-menu").hide();
      e(".button-dropdown .dropdown-toggle").removeClass("active");
      if (t) {
       e(this).parents(".button-dropdown").children(".dropdown- 
       menu").toggle().parents(".button-dropdown").children(".dropdown- 
       toggle").addClass("active")
       }
    });
    $('.dropdown-toggle').on('click', function() {
    $(this)
      .find('.changed')
      .toggleClass('fa-angle-down')
      .toggleClass('fa-angle-right');
    }); });
    Merci pour votre aide.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    • tu NE nous dit PAS si tu utilises Bootstrap ou pas (et quelle version ?), ou autre ?
    • ni si tu utilises un CMS (WP ? ... ?)
    • et tu ne montres pas le code HTML associé


    Que veux-tu qu'on te réponde ?...

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    175
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2008
    Messages : 175
    Par défaut Affichage du dropdown menu
    Merci pour votre réponse.

    J'utilise framework Materialaze 1.0.0 et Jquery 3.3.1

    Voila la partie de mon code HTML qui contient markup du dropdown menu.

    Code HTML : 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
    <li class="button-dropdown">
      <a href="javascript:void(0)" class="dropdown-toggle"><i 
      class="material-
      icons">assignment</i>Text A<i class="fa fa-angle-right changed"></i> 
      </a>
      <ul class="dropdown-menu" style="display: none;">
        <li>
          <a onclick="load('param1', 'param2')"><i class="material-
          icons">library_books</i>Module 1</a>
        </li>
      </ul>
      <ul class="dropdown-menu" style="display: none;">
       <li>
          <a onclick="load('param1', 'param2')"><i class="material-
          icons">TextB</i>Module 2</a>
       </li>
      </ul>
    </li>
    <li class="button-dropdown">
      <a href="javascript:toggleDiv('myContent');" class="dropdown-toggle"><i 
      class="material-icons">assessment</i><span id="myContent">C</span><i 
      class="fa fa-angle-right changed"></i></a>
      <ul class="dropdown-menu" style="display: none;">
        <li>
          <a onclick="load('unitb1', 'Unit B - Reproduction and 
          Development')"><i 
          class="material-icons">library_books</i>Module 1</a>
        </li>
      </ul>
      <ul class="dropdown-menu" style="display: none;">
        <li>
          <a onclick="load('unitb2', 'Unit B > Module 2')"><i 
          class="material- 
          icons">description</i>Module 2</a>
        </li>
      </ul>
    </li>

    J'espère que c'est un peu clair maintenant. Merci encore.

  4. #4
    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,
    bien que conforme dans son utilisation,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    jQuery(document).ready(function(e), {
      e(".dropdown-toggle").click(function() {
      // ...
    e représentant l’objet jQuery, il est quand même préférable d'écrire, pour la cohérence d'écriture
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    jQuery(document).ready(function(), {
      $(".dropdown-toggle").click(function() {
      // ...
    tout le monde s'y retrouvera lorsqu'il lira ton code.

    Quels sont tous ces espaces présent dans ton code qui ne doivent pas manquer de générer des erreurs
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
       e(this).parents(".button-dropdown").children(".dropdown- 
       menu").toggle().parents(".button-dropdown").children(".dropdown- 
       toggle").addClass("active")
       }
    pour quoi ne pas écrire simplement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $(this).parents(".button-dropdown").children(".dropdown-menu").toggle().parents(".button-dropdown").children(".dropdown-toggle").addClass("active")
    ou peut être mieux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $(this).parents(".button-dropdown")
        .children(".dropdown-menu")
        .toggle()
        .parents(".button-dropdown")
        .children(".dropdown-toggle")
        .addClass("active")
    pour mieux « appréhender » le chaînage !

    Lorsque l'on écrit du code avec jQuery on ne met de code action dans les balises
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="javascript:toggleDiv('myContent');" class="dropdown-toggle">

    Commence donc par corriger ces points !

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    175
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2008
    Messages : 175
    Par défaut
    Merci beaucoup. J'ai suivi tes conseils et mon problème a été résolu.

    Grand chapeau.

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

Discussions similaires

  1. Affichage de menu dans un div
    Par cell dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 21/07/2006, 09h21
  2. [CSS] Pb d'affichage de menu
    Par frog43 dans le forum Mise en page CSS
    Réponses: 3
    Dernier message: 25/03/2006, 16h52
  3. [MySQL] Affichage du menu en boucle après requête effectuer
    Par leloup84 dans le forum PHP & Base de données
    Réponses: 14
    Dernier message: 08/02/2006, 14h44
  4. [Debutant]Affichage de menu
    Par Beleim dans le forum Windows
    Réponses: 5
    Dernier message: 19/07/2005, 11h26

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