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

Mise en page CSS Discussion :

Faire apparaitre un sous menu


Sujet :

CSS

  1. #1
    Membre à l'essai
    Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2006
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2006
    Messages : 31
    Points : 19
    Points
    19
    Par défaut Faire apparaitre un sous menu
    Bonjour,

    J'essai de faire en sorte que lorsque l'usager passe dessus ou clic sur le choix "Nous écrire" les autres choix du menu apparait mais ça ne fonctionne pas.

    Dans mon code html:
    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
     
    <div id="boitemenu">
      <ul id="menu">
      <li><a href="/index.php" target="_parent">Accueil</a></li>
        <li>Nous écrire</li>
          <ul id="sousmenu">
    	  <li><a href="mailto:inde@nikpik.net">Nous deux</a></li>
    	  <li><a href="mailto:pierre@nikpik.net">Pierre</a></li>
    	  <li><a href="mailto:anik@nikpik.net">Anik</a></li>
    	  <li><a href="mailto:webmestre@nikpik.net">Webmestre</a></li>
    	  </ul>
      <li><a href="/admin/index.php" target="_blank">Admin</a></li>
      </ul>
    </div>

    Dans mon css
    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
     
    #menu {
        list-style-type: none;
    	margin: 0;
        padding: 0;
        border: 0;
    }
    #menu li {
        float: none;
    }
    #sousmenu {
        list-style-type: none;
        display:none;
    	margin: 0;
        padding: 0;
        border: 0;
    }
    #sousmenu li {
        float: none;
    }
    #menu li a:hover {
        list-style-type: none;
        background-image:url(/image/dharma_wheel.png);
        background-repeat:no-repeat;
        background-position:1% 50%;
        padding-left:15px;
    }
    #menu li:hover > .sousMenu { 
        display: block; 
    }
    Merci.

  2. #2
    Membre habitué Avatar de landryx
    Inscrit en
    Décembre 2006
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 145
    Points : 129
    Points
    129
    Par défaut
    Citation Envoyé par nikicaillou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
          <ul id="sousmenu">
    Dans mon css
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    #menu li:hover > .sousMenu { 
        display: block; 
    }
    Merci.
    salut

    Deja dans ton code tu fais id=sousmenu et apres tu fais #menu li:hover > .sousMenu

  3. #3
    Membre à l'essai
    Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2006
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2006
    Messages : 31
    Points : 19
    Points
    19
    Par défaut
    C'est un code que j'ai récupéré mais je ne comprend pas vraiment la ligne.
    #menu li:hover > .sousMenu
    De plus ça ne fonctionne pas.

  4. #4
    Membre habitué Avatar de landryx
    Inscrit en
    Décembre 2006
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 145
    Points : 129
    Points
    129
    Par défaut
    Citation Envoyé par nikicaillou
    C'est un code que j'ai récupéré mais je ne comprend pas vraiment la ligne.
    #menu li:hover > .sousMenu
    De plus ça ne fonctionne pas.
    je crois que c'est pour faire apparaitre ton sousmenu quand on passe la souris sur le li qui contient le <ul class= "sousmenu" > sachant que plus haut tu as fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    #menu .soumenu
    {
     display: none;
     list-style-type: none;
     margin: 0;
     padding: 0;
     border: 0;
    }

  5. #5
    Rédacteur
    Avatar de MasterOfChakhaL
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2004
    Messages
    2 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2004
    Messages : 2 147
    Points : 3 264
    Points
    3 264
    Par défaut
    Citation Envoyé par nikicaillou
    #menu li:hover > .sousMenu
    cette ligne signifie que les règles qui suivent s'appliquent aux éléments dont la classe est "sousMenu" qui serait le descendant direct d'un élément li sur lequel se trouve la souris et qui serait (le li) un descendant (pas forcément direct) d'un élément dont l'id est "menu"

    Simple n'est-ce pas

    A savoir pour IE:
    Le :hover ne fonctionne que sur les liens (élément a)
    L'opérateur de sélection de descendance direct n'est pas reconnu

  6. #6
    Membre à l'essai
    Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2006
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2006
    Messages : 31
    Points : 19
    Points
    19
    Par défaut
    C'est ce que j'avais compris mais mon but est de le faire fonctionner le tout sur FireFox et Sarafi donc je ne comprends pas pourquoi ça ne fonctionne pas

  7. #7
    Rédacteur
    Avatar de MasterOfChakhaL
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2004
    Messages
    2 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2004
    Messages : 2 147
    Points : 3 264
    Points
    3 264
    Par défaut
    Salut,

    J'ai regardé un peu mieux ton code,

    Et je pense que ladryx t'as déjà donné la solution, ou du moins la localisation du problème.

    dans ton ul qui englobe le sous menu tu utilises un identifiant alors que la fameuse ligne #menu li:hover>.sousMenu fait référence à une classe.

    deux possibilités:
    soit tu écris #menu li:hover>#sousMenu
    OU
    alors tu écris <ul class="sousMenu">

    J'opterais pour la deuxième solution

  8. #8
    Membre à l'essai
    Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2006
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2006
    Messages : 31
    Points : 19
    Points
    19
    Par défaut
    Mon problème est réglé à moitié. Mon sous menu est toujours affiché, ce que je veux est qu'il s'affiche lorsque l'on passe la souris ou sur un clic et non en tout temps.

    Merci.

  9. #9
    Rédacteur
    Avatar de MasterOfChakhaL
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2004
    Messages
    2 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2004
    Messages : 2 147
    Points : 3 264
    Points
    3 264
    Par défaut
    Pour le click tu peux oublier avec css. Seul javascript te permettra de faire ca.

    Par contre, peut-être que ton sous menu est grand et que tu penses sortir de la zone alors que ce n'est pas le cas.

    Essaye de mettre une bordure temporairement afin de voir la place que le sous menu occupe. D'une certaine manière, c'est une facon de débugger ton css

    EDIT:
    en fait dans ton premier code, tu as cela:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    #sousmenu {
        list-style-type: none;
        display:none;
    	margin: 0;
        padding: 0;
        border: 0;
    }
    Je ne sais pas ce que tu as choisi (au niveau class/id et ./#) mais il faut apporter la même correction ici. De plus, souviens toi que les identifiants sont sensibles à la casse. Il faut donc écrire sousMenu et non sousmenu (d'après ton html)

  10. #10
    Membre à l'essai
    Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2006
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2006
    Messages : 31
    Points : 19
    Points
    19
    Par défaut
    J'ai corrigé le tout, voici ce que ça donne mais mon sous menu n'est plus affiché du tout et rien ne se passe lorsque je passe ma souris dessus. De plus même si je met une bordure, je ne la vois pas.

    Css
    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
     
    #menu {
        list-style-type: none;
        margin: 0;
        padding: 0;
        border: 0;
    }
    #menu li {
        float: none;
    }
    #menu li a:hover {
        list-style-type: none;
        background-image:url(/image/dharma_wheel.png);
        background-repeat:no-repeat;
        background-position:1% 50%;
        padding-left:15px;
    }
    .sousmenu {
        list-style-type: none;
        display:none;
    	margin: 0;
        padding: 0;
        border: 1;
    }
    .sousmenu li {
        float: none;
    }
     
    #menu li:hover > .sousmenu { 
        display: block; 
    }
    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
     
    <div id="boitemenu">
      <ul id="menu">
      <li><a href="/index.php" target="_parent">Accueil</a></li>
      <li><a href="http://photo.nikpik.net" target="_parent">Photos</a></li>
      <li>Itin&eacute;raire</li>
      <li><a href="/notes/notetransport.php" target="_parent">Notes de voyages</a></li>
      <li><a href="/pages/infoinde.php" target="_parent">Informations sur l'Inde</a></li>
      <li><a href="/pages/liensexternes.php" target="_parent">Liens externes</a></li>
      <li><a href="/pages/livredor.php" target="_parent">Livre d'Or </a></li>
      <li>Nous écrire</li>
          <ul class="sousmenu">
    	  <li><a href="mailto:inde@nikpik.net">Nous deux</a></li>
    	  <li><a href="mailto:pierre@nikpik.net">Pierre</a></li>
    	  <li><a href="mailto:anik@nikpik.net">Anik</a></li>
    	  <li><a href="mailto:webmestre@nikpik.net">Webmestre</a></li>
    	  </ul>
      <li><a href="/admin/index.php" target="_blank">Admin</a></li>
      </ul>
    </div>

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

Discussions similaires

  1. commande pour faire apparaitre un sous menu
    Par bcpcsi dans le forum Général Python
    Réponses: 2
    Dernier message: 15/05/2013, 20h32
  2. Faire appel au sous-menu Nouveau de windows
    Par SergioMaster dans le forum API, COM et SDKs
    Réponses: 3
    Dernier message: 24/01/2011, 08h54
  3. Comment faire apparaitre un 2ème menu ?
    Par petit bibi dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 21/08/2010, 18h25
  4. [vBulletin] Faire apparaitre les sous forum sur le forum parent
    Par sofidz dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 02/04/2007, 17h44
  5. faire apparaitre tableau avec menu deroulant
    Par jojo971 dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 15/06/2006, 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