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 lien


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 40
    Par défaut génération dynamique de lien
    Bonjour,

    j'ai dans un tableau une liste d'élément (obtenu avec une requête en AJAX), et je souhaiterai pour chaque élément créer une ligne dans un tableau avec 2 cellules, dans la première un lien avec un onclick() qui appelle une fonction javascript dans la page, et une deuxième cellule avec uniquement du texte.

    J'ai un problème avec le lien, je sais pas trop comment expliquer ça, voici le code :
    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
    while (i < long)
    {
    	// on récupère les infos du noeud courant dans le xml
    	var id = listeIng[i].getElementsByTagName("id")[0].firstChild.nodeValue;
    	var nom = listeIng[i].getElementsByTagName("nom")[0].firstChild.nodeValue;
    	var famille = listeIng[i].getElementsByTagName("famille")[0].firstChild.nodeValue;										
     
    	i++;
    	// ligne
    	var row = document.getElementById("liste_ing_small").insertRow(-1);
     
    	// cell 1
    	var TD_nom = row.insertCell(-1);
    	TD_nom.className = 'col_ing';
     
    	// lien vers ajout
    	var lien = document.createElement("a");
    	lien.href = "#";
    	lien.onclick = function(){ajout(id)};
    	var TXT_nom = document.createTextNode (nom);
    	lien.appendChild (TXT_nom);
    	TD_nom.appendChild(lien);
     
    	// cell 2
    	var TD_fam = row.insertCell(-1);
    	var TXT_fam = document.createTextNode (famille);
    	TD_fam.className = 'col_famille';
    	TD_fam.appendChild (TXT_fam);
     
    }
    Pour chaque élément de la liste les variables nom, id et famille ont une valeur différente.
    Pas de problème pour la cellule 2, sur chaque ligne j'affiche une valeur différente.
    Par contre pour le lien onclick, le lien se créé bien, mais le paramètre "id" est toujours le même, c'est le dernier de la liste.

    Un exemple, si j'ai 3 éléments :
    id=1, nom=nom1, fam=fam1
    id=2, nom=nom2, fam=fam2
    id=3, nom=nom3, fam=fam3

    Les 3 lignes que je rajoute seront comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <tr>
    	<td><a href="#" onclick="ajout(3)">Nom1</a></td>
    	<td>Fam1</td>
    </tr>
    <tr>
    	<td><a href="#" onclick="ajout(3)">Nom2</a></td>
    	<td>Fam2</td></tr>
    <tr>
    	<td><a href="#" onclick="ajout(3)">Nom3</a></td>
    	<td>Fam3</td>
    </tr>
    Comment pourrais je faire pour que ce paramètre varie aussi ?

    Merci

    (en espérant avoir étais clair)

  2. #2
    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 659
    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 659
    Billets dans le blog
    1
    Par défaut
    Sujet maintes fois abordé ici, une recherche t'aurais permis de trouver au moins une dizaine de posts traitait de cela ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    // lien vers ajout
    	var lien = document.createElement("a");
    	lien.href = "#";
            lien.param=id
    	lien.onclick = function(){ajout(this.param)};
    	var TXT_nom = document.createTextNode (nom);
    	lien.appendChild (TXT_nom);
    	TD_nom.appendChild(lien);
    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 !

  3. #3
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 40
    Par défaut
    Pour la recherche j'y ai bien pensé mais le problème c'est que je ne savais pas vraiment (et je ne sais toujours pas) comment formuler ma requête pour trouver les bons sujets. Je viens d'essayer 'lien dynamique function' dans le forum JS mais sans grand succès.

    Pour la réponse, je n'ai pas vraiment compris à quoi correspond le this.param. this correspond à la fonction dans lequel on est ? et param au paramètre de cette fonction ?
    J'avoue que je vois pas comment l'utiliser...

    Merci pour ta réponse en tout cas

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 397
    Par défaut
    this dans le cas présent correspond à "lien" puisque le onclick est posé sur "lien".

    Donc le this.param correspond à lien.param ici "id".

  5. #5
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 40
    Par défaut
    Ok merci pour cette explication, ça résout mon problème

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 19/03/2007, 01h49
  2. [Débutant][JDBC] Rendre "dynamique" le liens à la
    Par steelidol dans le forum JDBC
    Réponses: 2
    Dernier message: 27/04/2005, 15h42
  3. [FLASH MX] Gestion dynamique de liens
    Par guy2004 dans le forum Flash
    Réponses: 18
    Dernier message: 20/01/2005, 08h21
  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