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 :

Génération dynamique de div


Sujet :

JavaScript

  1. #1
    Membre Expert
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Par défaut Génération dynamique de div
    Bonjour,

    je cherches à fabriquer en js une div qui me servira de menu sur un clic droit.
    Mon point de départ est un fichier xml.

    Situation de départ :
    Dans mon fichier HTMl j'ai une balise div :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <div class="skin1" oncontextmenu="return false;" id="menuContext" onmouseout="hidemenu"></div>
    Lorsque j'appuie sur un bouton, je vais chercher un fichier xml du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <data>
       <MOTIF_ABSENCE id_ma="1" code_ma="CP" lib_ma="Congés payés"/>
       <MOTIF_ABSENCE id_ma="2" code_ma="DEJ" lib_ma="Pause déjeuner"/>
    </data>
    Je veux insérer dans ma div menuContext, une série de div+span pour chaque motif d'absence.

    Voici ce que j'ai fait actuellement :
    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
     
    function ConstruireDivAbsence(xml) {
    	var nodeList;
    	var node;
    	var i;
     
    	var divContext;
     
    	divContext = document.getElementById('menuContext');
     
    	// Création premier élément
    	var div = document.createElement("div");
    	div.id="---ABS";
    	div.className="menuitems";
    	div.onclick="remplir(this.id)";
    	div.onmouseover="highlight()";
    	div.onmouseout="lowlight()";
     
    	var span = document.createElement("span");
    	span.className="menuspan";
    	span.onmouseover="highlight()";
    	span.onmouseout="lowlight()";
    	span.innerHTML="&nbsp;";
     
    	div.appendChild(span);
    	divContext.appendChild(div);
     
    	nodeList = xml.getElementsByTagName("MOTIF_ABSENCE");
    	for (i=0;i<nodeList.length;i++) {
    		node = nodeList(i);
    		var div = document.createElement("div");
    		div.id=node.getAttribute("code_ma");
    		div.className="menuitems";
    		div.onclick="remplir(this.id)";
    		div.onmouseover="highlight()";
    		div.onmouseout="lowlight()";
     
    		var span = document.createElement("span");
    		span.className="menuspan";
    		span.onmouseover="highlight()";
    		span.onmouseout="lowlight()";
    		span.innerHTML=node.getAttribute("code_ma");
     
    		div.appendChild(span);
    		divContext.appendChild(div);
    	}
    }
    Ma div semble bien générée puisque sur un clic droit elle s'affiche. Seulement, lorsque je passe sur un span, la fonction highlight n'est pas lancée.
    Je ne comprends pas pourquoi

    Auriez-vous une idée?

    Merci d'avance

  2. #2
    Membre chevronné
    Inscrit en
    Novembre 2006
    Messages
    336
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 336
    Par défaut
    salut,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    span.onmouseover=highlight;

  3. #3
    Membre Expert
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Par défaut
    Cela marche impeccable pour le highlight et le lowlight.
    Mais j'ai un problème avec le remplir(this.id)

    en effet, j'aimerais juste définir l'appel de la fonction sur le onclick mais il me lance la fonction !
    le this.id étant indéfini ma fonction me génère une erreur.

    Bon je m'y remet voir si je trouve un moyen de le faire

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 658
    Billets dans le blog
    1
    Par défaut
    tous les evenement doivent être codés :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    obj.evenement=function(){lafonction()};
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  5. #5
    Membre Expert
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Par défaut
    Merci Spafy

    Je m'endormirais moins bête ce soir

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

Discussions similaires

  1. [PDF]Génération dynamique de PDF et stockage
    Par JeJerom dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 18/01/2006, 15h25
  2. VB - Génération dynamique de controles dans un forme
    Par jeanangel dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 19/12/2005, 21h09
  3. [DOM] Génération dynamique fichier xml
    Par Fabouney dans le forum Bibliothèques et frameworks
    Réponses: 3
    Dernier message: 03/10/2005, 09h45
  4. [SQL*Plus] génération dynamique du fichier de spool
    Par lalystar dans le forum Oracle
    Réponses: 3
    Dernier message: 06/12/2004, 10h44
  5. Réponses: 7
    Dernier message: 22/10/2004, 16h18

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