Joomladay francophone 2018 à Paris 18 et 19 mai

Menu accordéon

Réduire
X
  • Filtrer
  • Heure
  • Afficher
Tout effacer
nouveaux messages

  • Menu accordéon

    Bonjour,

    Je suis tombé sur un menu accordéon développé avec JQuery par Arnaud Kientz. J'ai trouvé très intéressant son développement.

    Comme souvent en informatique, on aimerais faire différemment...

    J'ai un peu modifier son code pour arriver à ce résultat sur mon site de test.

    Mon code JavaScript est:
    Code PHP:
    $(document).ready( function () {
     
        
    // Cacher les sous-menus : ce sont des blocs enfants des classes "parent" de Joomla
        
    $("ul.menu li.parent ul").hide();

        
    //Afficher les sous-menus actifs
        
    $("ul.menu li.active ul").show();

        
    // On associe une nouvelle action au clic sur un lien "parent"
        // J'ai modifié le .click en .mouseover
        
    $("ul.menu li.parent > a").mouseover( function () {
     
        
    // Si le sous-menu est visible, on le referme en slide
            
    if ($(this).next("ul:visible").length != 0) {
                
    // J'ai mis cette ligne en remarque pour empècher la refermeture au passage de la souris
                //$(this).next("ul").slideUp("normal", function () { $(this).parent().removeClass("open") } );
            
    }
     
        
    // Sinon on ferme tout ce qui pourrait déjà être ouvert, et on ouvre le menu concerné avec des slide
            
    else {
                $(
    "ul.menu ul").slideUp("normal", function () { $(this).parent().removeClass("open") });
                $(
    this).next("ul").slideDown("normal", function () { $(this).parent().addClass("open") } );
            }
     
        
    // On empêche de suivre les liens créant les sous-menus avec return false;
        // J'ai modifié afin de permettre l'accès au lien avec return true;
            
    return true;
        });
     
    } ) ; 
    La seule chose qui me dérange dans ce script, c'est que lorsque nous avons cliqué sur un lien d'un menu enfant, la page se recharge, le liens enfant n'est plus visible...

    Avez vous une proposition ?

    Merci d'avance.
    Alain

    Edit: problème résolu, code modifié.
    Dernière édition par al1pb à 01/09/2009, 17h14
    Un peu de pub: http://www.aplomb.ch

  • #2
    Ce script est très simple et fonctionne super chez moi mais j'avais laissé tombé vu qu'il fallait chipoté beaucoup pour faire cohabité Mootools et JQUERY.

    Commentaire


    • #3
      Envoyé par vorlox Voir le message
      Ce script est très simple et fonctionne super chez moi mais j'avais laissé tombé vu qu'il fallait chipoté beaucoup pour faire cohabité Mootools et JQUERY.
      Je ne suis pas programmeur et ai que peu de connaissance en javascript et ces bibliothèques. Mootools est intégré dans Joomla et utilisé par d'autres composantes ?

      Peut-il y avoir des conflis et altérer le fonctionnement de Joomla en chargeant JQuery ?

      Merci pour les explications.
      Un peu de pub: http://www.aplomb.ch

      Commentaire


      • #4
        En gros, j'utilise le Moomenu et en bref, lorsque j'utilise le Moomenu et l'accordéon JQuery, il utilise l'une ou l'autre suivant laquelle je déclare en 1e dans le <head> de l'index.php.

        Commentaire


        • #5
          Merci à al1pb pour le mail sympa

          En gros tous les blocs ul avec la classe "parent" ( c'est-à-dire ceux ayant des sous-menus ) sont cachés au début du script par la méthode .hide.
          Au passage, je me suis compliqué la tâche, puisque

          Code PHP:
          $(".parent ul").hide(); 
          suffit amplement.

          Si on clique sur un lien d'un sous-menu, joomla lui donne la classe "active", et il suffit donc de le montrer une fois que tous les sous-menus sont cachés :

          Code PHP:
              $(".parent ul").hide();
              $(
          ".active ul").show(); 
          Je vais l'ajouter au tuto je pense...

          Je ne suis juste un débutant en javascript qui apprend en testant et grâce à ce site : http://jquery.developpeur-web2.com/documentation.php, et grâce aux nombreux tutos sur le web ( notamment alsacréations pour ce script ).

          mootools est utilisé il me semble pour l'écriture d'articles sur le front-end, ce que je ne fais pas, et je n'ai d'ailleurs jamais eu de conflit avec JQuery.
          Donc j'ai tout fait pour supprimer mootools et les autres scripts, et n'utiliser que JQuery, afin d'alléger considérablement le poids de la page.
          250 ko d'économisé, c'est pas rien, mais il faudrait encore que je bosse sur les images.
          Un peu d'info... : http://www.unpeud.info
          Pyromaths : http://www.pyromaths.org

          Commentaire


          • #6
            Merci beaucoup pour ta réponse si rapide.

            La solution marche à merveille.

            Mais je crois malheureusement que vorlox a raison, le Jquery créer une erreur et empèche l'affichage de mon module RockSlideShow en haut à droite ...

            Salutations
            Alain
            Un peu de pub: http://www.aplomb.ch

            Commentaire


            • #7
              Envoyé par al1pb Voir le message
              Merci beaucoup pour ta réponse si rapide.

              La solution marche à merveille.

              Mais je crois malheureusement que vorlox a raison, le Jquery créer une erreur et empèche l'affichage de mon module RockSlideShow en haut à droite ...

              Salutations
              Alain
              C'est bien dommage vu la façon simple et correcte dont marche le script en JQuery

              Commentaire


              • #8
                Envoyé par vorlox Voir le message
                C'est bien dommage vu la façon simple et correcte dont marche le script en JQuery
                Je penses que ça vaut la peine d'ouvrir une discussion à ce sujet.
                Un peu de pub: http://www.aplomb.ch

                Commentaire


                • #9
                  je m'incruste vite fait, car j'ai fini par tester ce script dont vous faites l'éloge. Il marche bien en effet, mais seulement sur un niveau enfant. Dès qu'on a 2 niveaux d'enfants en cliquant ça referme le parent du haut. Dommage....j'ai failli me mettre à jquery !
                  Vive Joomla! http://www.joomlack.fr Tutoriels et extensions pour Joomla!. Livre création de template Joomla de plus de 200 pages.
                  http://www.template-creator.com Outil de création de templates
                  Module Maximenu CK - Megamenu, multicolonnes, chargement de module, description de lien, deroulement animé - Compatible Virtuemart, Hikashop

                  Commentaire


                  • #10
                    Oui, c'est prévu comme ça à la base, puisque je n'ai qu'un seul sous-niveau sur mon site
                    Ce que tu demandes doit pouvoir se faire simplement.
                    Un peu d'info... : http://www.unpeud.info
                    Pyromaths : http://www.pyromaths.org

                    Commentaire


                    • #11
                      ben du coup dans le dev de mon script mootools je me suis restreint à un seul sous-niveau également !
                      Simple tu dis ??? hmmm, je ne crois pas. Si tu as quelque chose à présenter de fonctionnel, je suis impatient

                      EDIT : je dis ça car ça fait presque 2 semaines que je m'arrache les cheveux sur un script multi-niveaux, et que la structure UL LI présente l'inconvénient que les parents englobent les enfants. Du coup tu dois appliquer une classe de fermeture et ouverture à chaque conteneur pour ne faire varier que celui qu'il te faut. Ensuite (parce que c'est pas fini sinon ce serait trop simple) tu es confronté au problème de hauteur des conteneurs qui n'est pas la même en fonction de l'état ouvert/fermé des enfants et sous-enfants... etc... maintenant peut-être que Jquery gère cela mieux que mootools ? je suis curieux, si c'est le cas ça peut vraiment m'intéresser
                      Dernière édition par ced1870 à 02/09/2009, 21h34
                      Vive Joomla! http://www.joomlack.fr Tutoriels et extensions pour Joomla!. Livre création de template Joomla de plus de 200 pages.
                      http://www.template-creator.com Outil de création de templates
                      Module Maximenu CK - Megamenu, multicolonnes, chargement de module, description de lien, deroulement animé - Compatible Virtuemart, Hikashop

                      Commentaire


                      • #12
                        Ha non non, je ne prétends rien, je pense à haute voix c'est tout. Il y a apparemment une difficulté à laquelle je n'ai pas pensé.
                        Tu peux me filer un code source d'un menu à plusieurs niveaux ? ( j'ai la flemme de modifier mon site juste pour avoir le code source )
                        Je regarderai un peu ce week-end si j'ai le temps
                        Un peu d'info... : http://www.unpeud.info
                        Pyromaths : http://www.pyromaths.org

                        Commentaire


                        • #13
                          Envoyé par ced1870 Voir le message
                          je m'incruste vite fait, car j'ai fini par tester ce script dont vous faites l'éloge. Il marche bien en effet, mais seulement sur un niveau enfant. Dès qu'on a 2 niveaux d'enfants en cliquant ça referme le parent du haut. Dommage....j'ai failli me mettre à jquery !
                          Merci beaucoup de l'avoir testé, comme ça tu vois ce que j'aimerais réusir a faire en modifiant un peu ton script.
                          Il est clair qu'il est loin d'être parfait, il n'utilise qu'un niveau.
                          Pour moi, JQuery ou Mootools, Joomla m'impose le choix de Mootools, de plus, je n'y comprends presque rien dans les 2 cas...
                          C'est un script très simple qui fait pas mal de chose en très peu de lignes.
                          Et encore merci à Arnaud d'être venu m'aider à le modifier.

                          A+ Alian
                          Un peu de pub: http://www.aplomb.ch

                          Commentaire


                          • #14
                            Envoyé par arnaud_k Voir le message
                            Ha non non, je ne prétends rien, je pense à haute voix c'est tout. Il y a apparemment une difficulté à laquelle je n'ai pas pensé.
                            Tu peux me filer un code source d'un menu à plusieurs niveaux ? ( j'ai la flemme de modifier mon site juste pour avoir le code source )
                            Je regarderai un peu ce week-end si j'ai le temps
                            C'est une discussion voisine à celle ci http://forum.joomla.fr/showthread.php?t=101785
                            Un peu de pub: http://www.aplomb.ch

                            Commentaire


                            • #15
                              Pour un menu multiple, voici une solution simple qui semble fonctionner chez moi :

                              Code PHP:
                              $("#current").parents("ul").show(); 
                              à la place de

                              Code PHP:
                              $(".active ul").show(); 
                              Merci de me faire parvenir des retours
                              Un peu d'info... : http://www.unpeud.info
                              Pyromaths : http://www.pyromaths.org

                              Commentaire

                              Annonce

                              Réduire
                              1 sur 2 < >

                              C'est [Réglé] et on n'en parle plus ?

                              A quoi ça sert ?
                              La mention [Réglé] permet aux visiteurs d'identifier rapidement les messages qui ont trouvé une solution.

                              Merci donc d'utiliser cette fonctionnalité afin de faciliter la navigation et la recherche d'informations de tous sur le forum.

                              Si vous deviez oublier de porter cette mention, nous nous permettrons de le faire à votre place... mais seulement une fois
                              Comment ajouter la mention [Réglé] à votre discussion ?
                              1 - Aller sur votre discussion et éditer votre premier message :


                              2 - Cliquer sur la liste déroulante Préfixe.

                              3 - Choisir le préfixe [Réglé].


                              4 - Et voilà… votre discussion est désormais identifiée comme réglée.

                              2 sur 2 < >

                              Assistance au forum - Outil de publication d'infos de votre site

                              Compatibilité: PHP 4.1,PHP4, 5, 6DEV MySQL 3.2 - 5.5 MySQLi from 4.1 ( @ >=PHP 4.4.9)

                              Support Version de Joomla! : | J!3.0 | J!2.5.xx | J!1.7.xx | J!1.6.xx | J1.5.xx | J!1.0.xx |

                              Version française (FR) D'autres versions sont disponibles depuis la version originale de FPA

                              UTILISER À VOS PROPRES RISQUES :
                              L'exactitude et l'exhaustivité de ce script ainsi que la documentation ne sont pas garanties et aucune responsabilité ne sera acceptée pour tout dommage, questions ou confusion provoquée par l'utilisation de ce script.

                              Problèmes connus :
                              FPA n'est actuellement pas compatible avec des sites Joomla qui ont eu leur fichier configuration.php déplacé en dehors du répertoire public_html.

                              Installation :

                              1. Téléchargez l'archive souhaitée : http://afuj.github.io/FPA/

                              Archive zip : https://github.com/AFUJ/FPA/zipball/master

                              2. Décompressez le fichier de package téléchargé sur votre propre ordinateur (à l'aide de WinZip ou d'un outil de décompression natif).

                              3. Lisez le fichier LISEZMOI inclus pour toutes les notes de versions spécifiques.

                              4. LIRE le fichier de documentation inclus pour obtenir des instructions d'utilisation détaillées.

                              5. Téléchargez le script fpa-fr.php à la racine de votre site Joomla!. C'est l'endroit que vous avez installé Joomla et ce n'est pas la racine principale de votre serveur. Voir les exemples ci-dessous.

                              6. Exécutez le script via votre navigateur en tapant: http:// www. votresite .com/ fpa-fr.php
                              et remplacer www. votresite .com par votre nom de domaine


                              Exemples:
                              Joomla! est installé dans votre répertoire web et vous avez installé la version française du fichier FPA:
                              Télécharger le script fpa-fr.php dans: /public_html/
                              Pour executer le script: http://www..com/fpa-fr.php

                              Joomla! est installé dans un sous-répertoire nommé "cms" et vous avez installé la version française du fichier FPA:
                              Télécharger le script fpa-fr.php dans: /public_html/cms/
                              Pour executer le script: http://www..com/cms/fpa-fr.php

                              En raison de la nature très sensible de l'information affichée par le script FPA, il doit être retiré immédiatement du serveur après son utilisation.

                              Pour supprimer le script de votre site, utilisez le lien de script de suppression fourni en haut de la page du script. Si le lien de suppression échoue pour supprimer le script, utilisez votre programme FTP pour le supprimer manuellement ou changer le nom une fois que le script a généré les données du site et le message publié sur le forum. Si le script est toujours présent sur le site, il peut être utilisé pour recueillir suffisamment d'informations pour pirater votre site. Le retrait du script empêche des étrangers de l'utiliser pour jeter un oeil à la façon dont votre site est structuré et de détecter les défauts qui peuvent être utilisé à vos dépends.
                              Voir plus
                              Voir moins
                              Travaille ...
                              X