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

JavaScript Discussion :

Construire son menu dynamiquement


Sujet :

JavaScript

  1. #1
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2008
    Messages
    242
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2008
    Messages : 242
    Points : 296
    Points
    296
    Par défaut Construire son menu dynamiquement
    Bonjour à tous,

    Voilà, j'ai commencé un projet afin de réaliser un menu dynamique.
    Il commence par "OnClick" sur un élement et déplie les enfants.
    Ensuite, ses enfants, peuvent avoir aussi des enfants qui se déplieraient vers la droite.
    Dans le code, j'en suis là:
    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
    32
    33
    34
    35
    36
    function GetJsonMenuItems() {
            return {
                "menu": {
                    "master": "1",
                    "master2": [
                        { "titre": "Sentra2", "lien": "http://..../" },
                        { "titre": "Escort2", "lien": "http://..../" }
                    ],
                    "master3": [
                        { "titre": "Sentra3", "lien": "http://..../" },
                        { "titre": "Escort3", "lien": "http://..../" },
                        {
                            "SousMaster": [
                                { "titre": "Sentra4", "lien": "http://..../" },
                                { "titre": "Escort4", "lien": "http://..../" }
                            ]
                        }
                    ]
                }
            };
        }
     
        function LoadTemplateHTML() {
     
        }
     
        function BuildMenu(menuitems, templatesHtml) {
     
        }
     
     
        $().ready(function() {
            var menuitems = GetJsonMenuItems();
            var templatesHtml = LoadTemplateHTML();
            BuildMenu(menuitems, templatesHtml);
        });
    Je voudrais bien trouver comment faire pour avoir des "templates" JS contenant les différents cas (=un enfant, un enfant avec un sous enfant et enfin un enfant avec un enfant et un sous enfant).

    Auriez-vous une idée?

    Merci d'avance.

    Cordialement,
    Mafyou.

  2. #2
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2008
    Messages
    242
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2008
    Messages : 242
    Points : 296
    Points
    296
    Par défaut
    Bon, j'ai trouvé une solution à mon problème :-)
    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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    function GetJsonMenuItems() {
            return {
                "menu": {
                    "master1": [
                        { "titre": "Sentra1", "lien": "http://..../" },
                        { "titre": "Escort1", "lien": "http://..../" },
                    ],
                    "master2": [
                        { "titre": "Sentra2", "lien": "http://..../" },
                        { "titre": "Escort2", "lien": "http://..../" },
                        {
                            "SousMaster": [
                                { "titre": "Sentra3", "lien": "http://..../" },
                                { "titre": "Escort3", "lien": "http://..../" }
                            ]
                        }
                    ]
                }
            };
        }
     
        function SimpleTemplate(titre, url, idx, anchor) {
            var template = $(".templateParentSimple").clone();
            template.removeClass("templateParentSimple").addClass("SimpleUL");
            template.attr("id", "templateParent" + idx);
            template.css("display", "block");
            template.children().html("<a href='" + url + "'>" + titre + "</a>");
            $(anchor).append(template);
        }
     
        function BuildMenu(menuitems) {
            var i = 1;
            $.each(menuitems.menu, function(key, value) {
                if (key) {
                    $.each(value, function (key2, value2) {
                        if (value2.titre) {
                            SimpleTemplate(value2.titre, value2.lien, i, ".row");
                        } else {
                            $.each(value2, function (key3, value3) {
                                $.each(value3, function (key4, value4) {
                                    SimpleTemplate(value4.titre, value4.lien, i, "#templateParent" + (i - 1));
                                });
                            });
                        }
                        i++;
                    });
                }
            });
        }
     
     
        $().ready(function() {
            var menuitems = GetJsonMenuItems();
            BuildMenu(menuitems);
        });

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

Discussions similaires

  1. [Free Pascal] Intégrer des valeurs dans un menu dynamique
    Par boullery dans le forum Free Pascal
    Réponses: 16
    Dernier message: 30/03/2005, 17h04
  2. Créer un sous-menu dynamiquement
    Par PurL dans le forum C++Builder
    Réponses: 4
    Dernier message: 09/09/2004, 10h31
  3. [JSP]menu dynamique en jsp
    Par laouedjahmed dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 22/03/2004, 10h50
  4. Menu dynamique sous Flash MX
    Par dens63 dans le forum Flash
    Réponses: 7
    Dernier message: 29/10/2003, 15h46

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