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 :

Pb avec insertBefore


Sujet :

JavaScript

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 247
    Points : 99
    Points
    99
    Par défaut Pb avec insertBefore
    Bonjour,

    Mon insertBefore ne fonctionne pas et je ne vois pas du totu pourquoi. Je vous montre tout de suite 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
    function date() {
     
    	if (document.getElementById('etat').options[document.getElementById('etat').selectedIndex].value == 'badr') {
     
    	if (document.getElementById('parti')) document.getElementById('suivi').removeChild(document.getElementById('parti'));
     
    	var newtr = document.createElement('tr');
    	var newth = document.createElement('th');
    	var newtd1 = document.createElement('td');
    	var newtd2 = document.createElement('td');
    	var newinput = document.createElement('input');
    	var texte1 = document.createTextNode("Date BADR");
    	var texte2 = document.createTextNode("Veuillez respecter le format JJ/MM/AAAA");
     
     
    	newtd2.appendChild(texte2);
     
    	newinput.type = 'text';
    	newtd1.appendChild(newinput);
     
    	newth.appendChild(texte1);
     
    	newtr.appendChild(newth);
    	newtr.appendChild(newtd1);
    	newtr.appendChild(newtd2);
    	newtr.id = 'badr';
     
    	var node = document.getElementById('obs');
    	document.getElementById('suivi').insertBefore(newtr,node);
    	}
    avec ceci pour l'html :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <table id="suivi">
    <tr>
    <th>Etat</th><td><select name="etat" id="etat" onChange="date();"><option value="0">Non renseigné</option><option value="badr">BADR</option><option value="parti">Parti</option></select></td><td></td>
    </tr>
    <tr id="obs">
    <th>Observations</th><td><textarea></textarea></td><td></td>
    </tr>
    </table>
    Avec un appendChild tout se passe à merveille mais mon enfant va à la fin de la liste des noeuds tr (ce qui est normal) alors que moi je le voudrai entre le 1er et 2ème... d'ou l'utilisation d'insertBefore (qui ne veut pas marcher!!)

    Merci pour votre aide

  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 637
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    cela doit provenir du fait que le insertNode ne peut se faire que dans un tbody ?
    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
    <script type='text/javascript'>
    function date() {
     
    	if (document.getElementById('etat').options[document.getElementById('etat').selectedIndex].value == 'badr') {
     
    	if (document.getElementById('parti')) {document.getElementById('suivi').removeChild(document.getElementById('parti'));}
     
    	var newtr = document.createElement('tr');
    	var newth = document.createElement('th');
    	var newtd1 = document.createElement('td');
    	var newtd2 = document.createElement('td');
    	var newinput = document.createElement('input');
    	var texte1 = document.createTextNode("Date BADR");
    	var texte2 = document.createTextNode("Veuillez respecter le format JJ/MM/AAAA");
     
     
    	newtd2.appendChild(texte2);
     
    	newinput.type = 'text';
    	newtd1.appendChild(newinput);
     
    	newth.appendChild(texte1);
     
    	newtr.appendChild(newth);
    	newtr.appendChild(newtd1);
    	newtr.appendChild(newtd2);
    	newtr.id = 'badr';
     
    	var mynode = document.getElementById('obs');
    	document.getElementById('tablebody').insertBefore(newtr,mynode);
    	}
    	}
    	</script>
    </head>
     
    <body>
    <table id="suivi">
    <tr>
    <th>Etat</th><td><select name="etat" id="etat" onchange="date();"><option value="0">Non renseigné</option><option value="badr">BADR</option><option value="parti">Parti</option></select></td><td></td>
    </tr><tbody id="tablebody">
    <tr id="obs">
    <th>Observations</th><td><textarea></textarea></td>
     
    <td></td>
    </tr>
    </tbody>
    </table>
    </body>
    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 régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 247
    Points : 99
    Points
    99
    Par défaut
    ah bon??
    J'ai déjà utilisé insertBefore sans tbody pourtant.
    C'est étrange ça..!
    Merci pour ton aide.

  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 637
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    ben part les noms de variable je n'ai fait qu'ajouter un tbody à ton code et il fonctionne ...
    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 régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 247
    Points : 99
    Points
    99
    Par défaut
    oui je sais qu'il fonctionne et je te remercie.
    C'est juste que je ne vois pas pourquoi on doit ajouter un tbody et pourquoi les insertnode ne fonctionnent pas pour tous les éléments.
    Mais bon tant qu'on connait une astuce pour y remédier ça me va qd meme
    Merci

  6. #6
    Expert confirmé
    Avatar de siddh
    Inscrit en
    Novembre 2005
    Messages
    3 868
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Novembre 2005
    Messages : 3 868
    Points : 5 011
    Points
    5 011
    Par défaut
    ben la il insérait avant le tbody en fait.

    meme si tu n'en met pas dans une table, il y en a un dans l'arbre dom
    Alunissage : Procédé technique consistant à déposer des imbéciles sur un rêve enfantin.

    Cours | FAQ | Sources Javascript
    Cours | FAQ | Sources PHP
    Mes Articles

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 247
    Points : 99
    Points
    99
    Par défaut
    ah ok je comprends mieux...
    Il y a un moyen de voir le DOM de mon document ? (l'arborescence)

  8. #8
    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 637
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    si tu utilises firefox oui ...
    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 !

  9. #9
    Expert confirmé
    Avatar de siddh
    Inscrit en
    Novembre 2005
    Messages
    3 868
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Novembre 2005
    Messages : 3 868
    Points : 5 011
    Points
    5 011
    Alunissage : Procédé technique consistant à déposer des imbéciles sur un rêve enfantin.

    Cours | FAQ | Sources Javascript
    Cours | FAQ | Sources PHP
    Mes Articles

  10. #10
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 247
    Points : 99
    Points
    99
    Par défaut
    Merci !

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

Discussions similaires

  1. requete avec OBCD et visual c++
    Par Anonymous dans le forum MFC
    Réponses: 12
    Dernier message: 18/11/2004, 16h15
  2. [langage] Comparer Perl avec d'autres langages comme C ?
    Par Anonymous dans le forum Langage
    Réponses: 3
    Dernier message: 10/08/2002, 23h52
  3. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10
  4. [Kylix] Runtime error 230 avec INDY
    Par Anonymous dans le forum EDI
    Réponses: 2
    Dernier message: 23/03/2002, 11h51
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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