Partage
  • Partager sur Facebook
  • Partager sur Twitter

Menu responsive toujours ouvert

    6 avril 2020 à 12:23:17

    Bonjour à tous,

    je rencontre un petit soucis sur un menu en responsive. Celui-ci est toujours ouvert par default ce qui est problématique pour la navigation.

    j'ai isolé la partie du js concernant le soucis mais impossible de trouver quelque choqe qui marche :(

    <pre class="brush: jscript;">function getHtmlHide(nIpad,numLiItem)
     {
      var htmlLiHide="";
      if($("#more_menu").length==0)
        for(var i=(nIpad+1);i<=numLiItem;i++)
          htmlLiHide+='<li>'+$('#_desktop_top_menu_pk ul.menu-content li.level-1:nth-child('+i+')').html()+'</li>';
      return htmlLiHide;
    }

    function addMoreResponsive(nIpadHorizontal,nIpadVertical,htmlLiH,htmlLiV,htmlMenu)
    {
      if(nIpadHorizontal>0 && nIpadVertical>0)
      {
        if($("#more_menu").length>0)
          $("#_desktop_top_menu_pk .container").html(htmlMenu);

        if($(window).width() > 750 && $(window).width() <= 992)
        {
          if($("#more_menu").length==0)
          {
            $('<li id="more_menu" class="level-1 more-menu"><a href="#"><span class="icon-plus"></span>' + text_more + '</a><ul class="menu-dropdown cat-drop-menu pk-sub-auto">' + htmlLiV + '</ul></li>').insertAfter('#_desktop_top_menu_pk ul.menu-content li.level-1:nth-child('+nIpadVertical+')');
          }
          if($("#more_menu").length>0)
            for(var j=(nIpadVertical+2);j<=(numLiItem+1);j++)
            {
              $("#_desktop_top_menu_pk ul.menu-content li:nth-child("+j+").level-1").remove();
              var delItem=nIpadVertical+2;
              $("#_desktop_top_menu_pk ul.menu-content li:nth-child("+delItem+").level-1").remove();
            }
        }
        else if($(window).width() > 992 && $(window).width() <= 1199)
        {
          if ($("#more_menu").length==0)
            $('<li id="more_menu" class="level-1 more-menu"><a href="#"><span class="icon-plus"></span>' + text_more + '</a><ul class="menu-dropdown cat-drop-menu pk-sub-auto">' + htmlLiH + '</ul></li>').insertAfter('#_desktop_top_menu_pk ul.menu-content li.level-1:nth-child('+nIpadHorizontal+')');
          if($("#more_menu").length>0)
            for(var j=(nIpadHorizontal+2);j<=(numLiItem+1);j++)
            {
              $("#_desktop_top_menu_pk ul.menu-content li:nth-child("+j+").level-1").remove();
              var delItem=nIpadHorizontal+2;
              $("#_desktop_top_menu_pk ul.menu-content li:nth-child("+delItem+").level-1").remove();
            }
        }
      }
    }

    $(document).ready(function()
    {

      $('.icon_menu').click(function(){
        $(this).next().toggle();
      });

      $container_width = $('#header').width();
      $.each($('#top-menu .menu-dropdown'), function(index, element) {
        if (!$(element).hasClass('pk-sub-right')) {
          $elem_width = $(element).width();
          $elem_offset = $(element).offset();
          totalWidth = parseInt($elem_offset.left)+parseInt($elem_width);
          if (totalWidth > $container_width) {
            $(this).addClass('pk-sub-right');
          }
        }
      });

      var breakpoint = 1024;

      if ($(window).width() < breakpoint) {
        $('#_desktop_top_menu_pk ul.menu-content').css('display', 'none');
      }
      $(window).resize(function(){
        if($(window).width() < breakpoint) {
          $('#_desktop_top_menu_pk ul.menu-content').css('display', 'none');
        }
        else {
          $('#_desktop_top_menu_pk ul.menu-content').css('display', 'none');
        }
      });

      var w = $(window).width();
      if (w > breakpoint) {
        var timer;
        var dd_cont = '.pk-sub-menu';
        $('#top-menu .parent').hover(
            function () {
                clearTimeout(timer);
                $(dd_cont).not($(this).parents().not(".dd_el_hover")).stop().slideUp(0);
                $(this).children(dd_cont).stop().slideDown(500, 'easeOutExpo');
                $(this).addClass('dd_el_hover');
            },
            function () {
                var $self = $(this).children(dd_cont);
                timer = setTimeout(function() {
                    $self.stop().slideUp(0);
                    $(this).removeClass('dd_el_hover');
                }, 50);
            }
        );
      }

    });</pre>.



    -
    Edité par SamuelAvril2 6 avril 2020 à 14:41:42

    • Partager sur Facebook
    • Partager sur Twitter
      6 avril 2020 à 12:40:29

      Bonjour,

      Le message qui suit est une réponse automatique activée par un membre de l'équipe. 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: jscript;">Votre code ici</pre>.

      Merci de modifier votre message d'origine en fonction.

      Liens conseillés

      • Partager sur Facebook
      • Partager sur Twitter

      Menu responsive toujours ouvert

      × 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