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 :

Récupérer le contenu d'un <td> en javascript


Sujet :

JavaScript

  1. #1
    Membre régulier
    Inscrit en
    Novembre 2003
    Messages
    173
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 173
    Points : 99
    Points
    99
    Par défaut Récupérer le contenu d'un <td> en javascript
    Bonjour à tous.
    J'ai une <table> que je rempli par une function Javascript à partir d'un formulaire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    function ajout(f, calTot)
    	{
    	var t=document.getElementById("Panier").tBodies[0];
            var tr, td;
     	tr=document.createElement("tr");
    		for(i=1;i<5;i++)
    		{
    			td=document.createElement("td");
    			td.appendChild(document.createTextNode(f[i].value));
    			tr.appendChild(td);
    		}
    sur double click sur une ligne j'efface toute la ligne par le code suivant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    tr.ondblclick = function()
    		{
      			this.parentNode.removeChild( this);
    		}
    ça marche très bien. Avant la suppression de la ligne, je voudrais récupérer le contenu d'un <td> (le 4ème) de cette ligne. Pouvez-vous m'indiquer comment procéder. Merci d'avance.

  2. #2
    Membre confirmé
    Avatar de Darkaurora
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2010
    Messages
    382
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2010
    Messages : 382
    Points : 549
    Points
    549
    Billets dans le blog
    1
    Par défaut
    Malheureusement en JS pure je ne sais pas. !en JQuery par contre ça serait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $( 'tr' ).on( 'dblclick', function( ) {
    var tmpText = $( this ).find( td:eq(3) ).text( );
    $( this ).remove( );
    } );

  3. #3
    Membre régulier
    Inscrit en
    Novembre 2003
    Messages
    173
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 173
    Points : 99
    Points
    99
    Par défaut
    Je ne connais rien à jQuery.En tout cas, merci Darkaurora.

  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 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    tr.ondblclick = function()
    		{
    alert(this.getElementsByTagName('td')[3].innerHTML)  			
    this.parentNode.removeChild( this);
    		}

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2013
    Messages : 12
    Points : 18
    Points
    18
    Par défaut
    Bonjour,

    Je suis d'accord avec la réponse de SpaceFrog mais je pense qu'il serait peut être plus judicieux d'utiliser .textContent à la place de .innerHTML
    En effet .innerHTML récupère aussi les balises HTML alors que textContent ne récupère que le texte.

    Par exemple : http://jsfiddle.net/quRkQ/1/
    Dans cette exemple il y la solution à ton problème et si tu tentes de supprimer la 4ème ligne tu verras la différence entre textContent et innerHTML. Tu choisiras selon ton besoin.

    En espérant avoir pu aider.

    PS: je rajouterais juste au passage que cela dépend le comportement que tu veut avoir mais il est préférable de ne pas attacher ces événement en utilisant la syntaxe :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    element.ondblclick  = function(){ /* do something */ };
    mais plutôt avec addEventListener (+ attachEvent pour la compatibilité IE < 9 )
    Pour voir la différence et te faire une idée > http://jsfiddle.net/mLHv8/

  6. #6
    Membre régulier
    Inscrit en
    Novembre 2003
    Messages
    173
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 173
    Points : 99
    Points
    99
    Par défaut
    Merci beaucoup j'ai opter pour ".textContent" et ça marche bien. Vous m'avez bien aidé.

  7. #7
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Attention textContent n'est pas supporté chez IE < 9

  8. #8
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2013
    Messages : 12
    Points : 18
    Points
    18
    Par défaut
    Oui, après on trouve toujours des polyfills qui permettent de gérer le soucie de compatibilité si c'est important pour nous. Pour moi par exemple je pense qu'il faut être compatible IE >= 8.
    IE 6 et 7 sont dorénavant obsolète.

    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
    if (Object.defineProperty && Object.getOwnPropertyDescriptor &&
         Object.getOwnPropertyDescriptor(Element.prototype, "textContent") &&
        !Object.getOwnPropertyDescriptor(Element.prototype, "textContent").get)
      (function() {
        var innerText = Object.getOwnPropertyDescriptor(Element.prototype, "innerText");
        Object.defineProperty(Element.prototype, "textContent",
          { // It won't work if you just drop in innerText.get
            // and innerText.set or the whole descriptor.
            get : function() {
              return innerText.get.call(this)
            },
            set : function(x) {
              return innerText.set.call(this, x)
            }
          }
        );
      })();
    voila le script ici à insérer seulement si le navigateur est IE8 pour le rendre compatible. (trouvé ici)

  9. #9
    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 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    IE 6 et 7 sont dorénavant obsolète.
    Dans le meilleurs des mondes ...

  10. #10
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 079
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 079
    Points : 44 663
    Points
    44 663
    Par défaut
    Bonjour,
    j'aurais simplement fait un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var content = this.cells[3].textContent || this.cells[3].innerText;

  11. #11
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Idem que NoSmoking, car en plus c'est compatible IE < 8, contrairement à la solution de MisterPur. Qui est néanmoins sexy ! (la solution, hein )

  12. #12
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    A noter que innerText et textContent ne font pas exactement la même chose : sur IE, innerText ne renvoie pas le texte des <script> , <style> et éléments cachés

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

Discussions similaires

  1. [Servlet]Récupérer le contenu d'une page web
    Par Jarodnet dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 06/10/2005, 15h47
  2. Récupérer le contenu de la balise title
    Par roots dans le forum Langage
    Réponses: 2
    Dernier message: 11/09/2005, 16h17
  3. Récupérer le contenu d'un select
    Par PrinceMaster77 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 23/08/2005, 15h38
  4. [ethereal] récupérer le contenu d'un fichier envoyé ?
    Par in dans le forum Développement
    Réponses: 1
    Dernier message: 19/06/2005, 15h44
  5. [Balise XML] Comment récupérer le contenu entre 2 balise?
    Par ZoumZoumMan dans le forum C++Builder
    Réponses: 5
    Dernier message: 05/03/2004, 16h36

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