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 :

[DOM] childNodes.length Incohérent


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Par défaut [DOM] childNodes.length Incohérent
    Bonjour,

    J'ai une structure de cette forme :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <tbody>
    <tr id="un"></tr>
    <tr id="deux"></tr>
    <tr id="trois"></tr>
    </tbody>
    Quand j'effectue un childNodes.length pour connaître le nombre d'enfant de la balise <tbody>, il me sort qu'il y en a quatre.
    Quand je demande à afficher l'id du dernier enfant, il m'affiche l'id du 2nd (c'est à dire "deux" au lieu de "trois").

    Quelqu'un aurait-il une idée pour résoudre cette énigme?

    Merci par avance

  2. #2
    Expert éminent

    Avatar de vermine
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    6 582
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 6 582
    Par défaut
    Bonjour,

    Pourrions-nous avoir un peu plus de code ?
    A savoir la structure complète de la table (vous n'avez pas de <td> ?) et le code qui sélectionne le childNodes.length.

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Par défaut
    Bonjour,

    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
     
    <table id="chapitre_table_1">
     <tbody id="tbodyalanoix">
      <tr id="tcha_1">
       <td>Titre du chapitre : </td>
       <td><textarea cols="50" rows="1" name="tcha_1" ></textarea></td>
       <td><input type="button" value="ajouter_chapitre" onclick="ajouter_chapitre()"></input></td>
      </tr>  
      <tr id="tr_schapitre_table_11">
      <table id="schapitre_table_11">
       <tr id="tsch_11">
        <td>Titre du sous-chapitre : </td>
        <td><textarea cols="50" rows="1" name="tsch_11"></textarea></td>
        <td><input type="button" value="ajouter_schapitre" onclick="ajouter_schapitre(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
       </tr>
       <table id="id_table_para_111">
        <tr id="para_111">
         <td>Contenu du paragraphe : </td>
         <td><textarea cols="80" rows="10" name="para_111"></textarea></td>
         <td><input type="button" value="ajouter_paragraphe" onclick="ajouter_paragraphe(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
        </tr>
       </table>
      </table>
      </tr>   
      <tr id="tr_schapitre_table_12">
      <table id="schapitre_table_12">
       <tr id="tsch_12">
        <td>Titre du sous-chapitre : </td>
        <td><textarea cols="50" rows="1" name="tsch_12"></textarea></td>
        <td><input type="button" value="ajouter_schapitre" onclick="ajouter_schapitre(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
       </tr>
       <table id="id_table_para_121">
        <tr id="para_121">
         <td>Contenu du paragraphe : </td>
         <td><textarea cols="80" rows="10" name="para_121"></textarea></td>
         <td><input type="button" value="ajouter_paragraphe" onclick="ajouter_paragraphe(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
        </tr>
       </table>
      </table>
      </tr>
      </tbody>
     </table>
    Voici le code complet.
    La fonction javascript que j'appelle contient ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    window.alert(document.getElementById('tbodyalanoix').childNodes.length);
    window.alert(document.getElementById('tbodyalanoix').lastChild.id);

  4. #4
    Expert éminent

    Avatar de vermine
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    6 582
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 6 582
    Par défaut
    J'ai exécuté votre code et il m'annonce deux lignes dans le <thead> et "tr_schapitre_table_11" comme lastChild.id.

    Ce qui tombe plutôt bien vu que c'est ce qui est créé.


    PS : j'ai testé sous IE7.

  5. #5
    Expert confirmé
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 100
    Par défaut
    Tu oublies des tas de <tr> et de <td> quand tu mets des sous-tables… Les moteurs JavaScript sont balèzes quand il s’agit de compléter les trous du DOM, mais faut quand même pas pousser.

    Avec le code suivant (qui passe la validation), j’obtiens 7 pour childNodes.length, ce qui est normal avec les nœuds #text.

    Code HTML : 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
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8" />
    <title>Tbody à la noix</title>
    </head>
    <body>
     
    <table id="chapitre_table_1">
      <tbody id="tbodyalanoix">
        <tr id="tcha_1">
          <td>Titre du chapitre : </td>
          <td><textarea cols="50" rows="1" name="tcha_1" ></textarea></td>
          <td><input type="button" value="ajouter_chapitre" onclick="ajouter_chapitre()"></input></td>
        </tr>  
        <tr id="tr_schapitre_table_11">
          <td>
            <table id="schapitre_table_11">
              <tr id="tsch_11">
                <td>Titre du sous-chapitre : </td>
                <td><textarea cols="50" rows="1" name="tsch_11"></textarea></td>
                <td><input type="button" value="ajouter_schapitre" onclick="ajouter_schapitre(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
              </tr>
              <tr>
                <td>
                  <table id="id_table_para_111">
                    <tr id="para_111">
                      <td>Contenu du paragraphe : </td>
                      <td><textarea cols="80" rows="10" name="para_111"></textarea></td>
                      <td><input type="button" value="ajouter_paragraphe" onclick="ajouter_paragraphe(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
                    </tr>
                  </table>
                </td>
              </tr>
            </table>
          </td>
        </tr>   
        <tr id="tr_schapitre_table_12">
          <td>
            <table id="schapitre_table_12">
              <tr id="tsch_12">
                <td>Titre du sous-chapitre : </td>
                <td><textarea cols="50" rows="1" name="tsch_12"></textarea></td>
                <td><input type="button" value="ajouter_schapitre" onclick="ajouter_schapitre(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
              </tr>
              <tr>
                <td>
                  <table id="id_table_para_121">
                    <tr id="para_121">
                      <td>Contenu du paragraphe : </td>
                      <td><textarea cols="80" rows="10" name="para_121"></textarea></td>
                      <td><input type="button" value="ajouter_paragraphe" onclick="ajouter_paragraphe(this.parentNode.parentNode.parentNode.parentNode.id)"></input></td>
                    </tr>
                  </table>
                </td>
              </tr>
            </table>
          </td>
        </tr>
      </tbody>
    </table>
     
    </body>
    </html>



    ( Ça c’est bonus : [ame="http://www.google.fr/search?hl=fr&q=mise+en+page+tableaux"]mise en page tableaux - Recherche Google[/ame] )
    La FAQ JavaScript – Les cours JavaScript
    Touche F12 = la console → l’outil indispensable pour développer en JavaScript !

  6. #6
    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
    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 !

Discussions similaires

  1. Javascript DOM childNodes different avec IE et FF
    Par SPACHFR dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 23/09/2010, 17h39
  2. Réponses: 11
    Dernier message: 09/06/2010, 15h06
  3. [XMl/DOM/ChildNodes] Liste des filles directes d'une branche
    Par eracius dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 14/01/2008, 19h37
  4. [DOM] DOM childNodes IE vs FFX
    Par yaya0057 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 13/07/2007, 14h52
  5. [DOM] Création d'un noeud xml avec childNode
    Par starr dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 22/03/2007, 11h18

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