Partage
  • Partager sur Facebook
  • Partager sur Twitter

problème de sous menus de ma barre de nav

    18 août 2023 à 11:52:50

    Bonjour 


    je m'entraine à créer un site et je bloque sur un soucis de navbar, mes sous menus s'enlevent si je bouge des onglets donc pas le temps de naviguer dessus et cliquer sur un lien, je voudrais qu'au survol d'un onglet, le sous menu reste affiché sans partir des que je bouge la souris


    voici mon html de ma nav et le css associé 


    si vous avez une astuce je suis preneur


    merci :)


    <nav>
          <div class="onglets">
            <ul>
              <li><a href="../tRAINING CODE/index.html">Accueil</a></li>
              <li class="deroulant">
                <a href="../tRAINING CODE/mangas.html">Mangas</a>
                <ul class="sous">
                  <li class="petit"><a href="">Shonen</a></li>
                  <li class="petit"><a href="#">Seinen</a></li>
                  <li class="petit"><a href="#">Shojo</a></li>
                  <li class="petit"><a href="#">Josei</a></li>
                  <li class="petit"><a href="#">Yuri</a></li>
                  <li class="petit"><a href="#">Yaoi</a></li>
                </ul>
              </li>
              <li class="deroulant">
                <a href="../tRAINING CODE/figurines.html">Figurines</a>
                <ul class="sous">
                  <li class="petit"><a href="#">One Piece</a></li>
                  <li class="petit"><a href="#">Dragon Ball</a></li>
                  <li class="petit"><a href="#">Naruto</a></li>
                  <li class="petit"><a href="#">Demon Slayer</a></li>
                  <li class="petit"><a href="#">My Hero Academia</a></li>
                  <li class="petit"><a href="bleach.html">Bleach</a></li>
                  <li class="petit"><a href="#">One Punch Man</a></li>
                </ul>
              </li>
              <li><a href="../tRAINING CODE/pop.html">Figurines POP</a></li>
              <li class="deroulant">
                <a href="../tRAINING CODE/vetements.html">Vêtements & Accessoires</a>
                <ul class="sous">
                  <li class="petit"><a href="#">Casquettes</a></li>
                  <li class="petit"><a href="#">Sweatshirts</a></li>
                  <li class="petit"><a href="#">T-Shirts</a></li>
                  <li class="petit"><a href="#">Bijoux</a></li>
                  <li class="petit"><a href="#">Goodies</a></li>
                </ul>
              </li>
              <li><a href="../tRAINING CODE/cosplay.html">Cosplay</a></li>
              <li><a href="../tRAINING CODE/friandises.html">Friandises</a></li>
            </ul>
          </div>
        </nav>



    nav{
      display: flex;
      position: sticky;
      top: 150px; /* Ajustez cette valeur en fonction de la hauteur de votre en-tête */
      width: 100%;
      z-index: 99;
      background-color: white;
      justify-content: center
    }
    .onglets {
        display: inline-block;
        list-style-type: none;
        margin: 0;
        padding: 0;
        text-align: center;
        border: solid rgb(250, 0, 0) 1px;
        border-radius: 16px;
      }
      .onglets li {
        display: inline-block;
        position: relative;
        margin: 0 40px 0 0; /* Ajustez la valeur selon l'espacement souhaité */
        cursor: pointer;
      }
      .onglets li a {
        display: flex;
        align-items: center;
        text-decoration: none;
        color: black;
        font-size: 1.5em; /* Ajustez la valeur selon la taille de police souhaitée */
        z-index: 1;
      }
      .onglets li::before {
        content: '';
        position: absolute;
        top: -10px;
        left: -10px;
        right: -10px;
        bottom: -10px;
        z-index: 0;
        opacity: 0;
        background-color: #ff0000c7;
        border-radius: 20px;
        transition: opacity 0s;
        pointer-events: none;
      }
      .onglets li:hover::before {
        opacity: 0.5;
        z-index: 0;
      }

      .onglets .sous {
        display: none;
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        background-color: #ffffffd3;
        padding: 0;
        border-radius: 20px;
      }
      .onglets .sous li {
        display: flex ;
        white-space: nowrap;
        margin: 15px 10px 20px 10px;
        justify-content: center;
      }

      .onglets .sous li a {
        font-size: 15px;
        margin: 10px;
      }
      .onglets .deroulant:hover .sous {
        display: block;
        margin-top: 10px;
      }



    • Partager sur Facebook
    • Partager sur Twitter
      18 août 2023 à 12:09:27

      Bonjour, évitez les titres de sujet avec "problème", si vous postez on se doute que vous avez un problème inutile de l'indiquer dans le titre cela n'apporte rien de plus comme information quant au contenu du sujet.

      Le message qui suit est une réponse automatique activée par un membre de l'équipe de modération. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Merci de colorer votre code à l'aide du bouton Code

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: xml;">Votre code ici</pre>.

      Merci de modifier votre message d'origine en fonction.

      Liens conseillés

      -
      Edité par AbcAbc6 18 août 2023 à 12:48:32

      • Partager sur Facebook
      • Partager sur Twitter
        18 août 2023 à 16:31:05

        Bonjour. Il ne doit pas y avoir d'espace entre un sous-menus et son élément "père", sinon tu le quittes.

        Tu peux par exemple, au lieu de...

        .onglets .sous {
            top: 100%;
            padding: 0;
        }

        ... faire

        .onglets .sous {
            top: 80%;
            padding: 1em 0 0 0;
        }



        -
        Edité par Domi65 18 août 2023 à 16:32:10

        • Partager sur Facebook
        • Partager sur Twitter

        problème de sous menus de ma barre de nav

        × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
        × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
        • Editeur
        • Markdown