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 :

Insertion dynamique de lignes en colonne dans un tableau


Sujet :

JavaScript

  1. #1
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut Insertion dynamique de lignes en colonne dans un tableau
    Bonsoir,

    Je réalise une saisie de lignes en ajax

    J'ai un formulaire html pour la saisie de la ligne à ajouter, un javascript pour l'ajout de la ligne sur le formulaire et un script php pour la mise à jour dans la base de données.

    Tout fonctionne bien, j'ai juste maintenant un problème de présentation

    Mon formulaire est décomposé en 3 parties
    1 - Entête des colonnes (comme un tableur) avec date, heure, contact et commentaire
    2 - Le corps de mon formulaire alimenté par mon javascript avec les champs correspondants aux colonnes définis dans l'entête
    3 - La ligne de saisie qui me permet de saisir pour alimenter le corps.

    Je n'arrive pas à cadrer les 3 parties, les colonnes se décalent.

    J'ai fini par mettre en tableau la partie 1, la partie 3. Pour la partie 2 je n'y arrive pas.

    Un peu de code maintenant pour être plus clair.

    Les parties 1, 2 et 3

    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
    <div id="tableContainer" class="tableContainer">
    	<table width="100%" class="scrollTable">
    	<colgroup>
    	<col width="9%"/>
    	<col width="5%"/>
    	<col width="10%"/>
    	<col width="50%"/>
    	<col width="10%"/>
    	<col width="10%"/>
    	</colgroup>
    		<thead class="fixedHeader">
    			<tr align="left">
    				<td class="t_titre" >Date</td>
    				<td class="t_titre" >Heure</td>
    				<td class="t_titre" >Contact</td>
    				<td class="t_titre" >Texte</td>
    				<td class="t_titre" >Origine</td>
    				<td class="t_titre" >Action</td>
    			</tr>
    		</thead>
     
    	<tbody class="scrollContent" id="tableau">
     
     
    </table>
    </div>
    </fieldset>
    	<table width="100%">
    	<colgroup>
    	<col width="9%">
    	<col width="5%">
    	<col width="10%">
    	<col width="50%">
    	<col width="10%">
    	<col width="10%">
    	</colgroup>
    		<tr>
    </tr>
    		<tr>
    			<td>
    				<input type="button" name="Valider" onclick="ajouterLigne();" value="Valider" class="button">
    			</td>
    		</tr>
    	</table>
    J'avais essayé avec des div, puis je suis passé au tableau.

    Mon problème est que le colgroup ne s'applique à mes lignes ajoutées.
    Voici le javascript :

    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
    ligne = document.createElement ('tr');
    	cell = document.createElement ('td');
    	texte = document.createTextNode (date);
    	cell.appendChild (texte);
    	ligne.appendChild(cell);
    	cell = document.createElement ('td');
    	texte = document.createTextNode (heure);
    	cell.appendChild (texte);
    	ligne.appendChild(cell);
    	cell = document.createElement ('td');
    	texte = document.createTextNode (contact);
    	cell.appendChild (texte);
    	ligne.appendChild(cell);
    	cell = document.createElement ('td');
    	texte = document.createTextNode (commentaire);
    	cell.appendChild (texte);
    	ligne.appendChild(cell);
    ligne.appendChild(cell);
    	document.getElementById ('tableau').appendChild (ligne);
    Je pensais que mes lignes ajoutées puisqu'elles étaient en <td> prendraient les valeurs du colgroup.

    Merci de m'éclairer sur le sujet.

    Merci d'avance

  2. #2
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    la réponse s'appelle tbody
    il y a toujours un tbody quand il y a des ligne de donnée
    Table
    tBody
    tr
    td

    A+JYT

  3. #3
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Citation Envoyé par lodan
    [CODE]<div id="tableContainer" class="tableContainer">
    <table width="100%" class="scrollTable">
    <colgroup>
    <col width="9%"/>
    <col width="5%"/>
    <col width="10%"/>
    <col width="50%"/>
    <col width="10%"/>
    <col width="10%"/>
    </colgroup>
    <thead class="fixedHeader">
    <tr align="left">
    <td class="t_titre" >Date</td>
    <td class="t_titre" >Heure</td>
    <td class="t_titre" >Contact</td>
    <td class="t_titre" >Texte</td>
    <td class="t_titre" >Origine</td>
    <td class="t_titre" >Action</td>
    </tr>
    </thead>

    <tbody class="scrollContent" id="tableau">
    Merci pour ta réponse, mais j'ai déjà un tbody et je ne vois pas ce que cela change ?

  4. #4
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    tu ajoute un fils a table et non tbody
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById ('tableau').appendChild (ligne);

  5. #5
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Citation Envoyé par sekaijin
    tu ajoute un fils a table et non tbody
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById ('tableau').appendChild (ligne);
    Pas compris.
    J'ai déjà cette ligne dans mon JS.

    Si je place 'tableau' au niveau de <table>, le code sera avant mon entête et davant le <colgroup>

  6. #6
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    sorry j'avais pas vu que tableau c'était le tbody

    alors là je vois pas
    A+JYT

  7. #7
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Merci d'avoir essayé. Je continue de creuser.

  8. #8
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    J'ai réussi comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ligne = document.createElement('tr');
    	ligne.style.background = "#CCCCFF";
    	cell = document.createElement('td');
    	texte = document.createTextNode(document.getElementById('date').value);
    	cell.style.width = '80px';
    	cell.appendChild (texte);
    	ligne.appendChild(cell);
    	cell = document.createElement('td');
    	texte = document.createTextNode(document.getElementById('heure').value);
    	cell.style.width = '60px';
    	cell.appendChild (texte);
    	ligne.appendChild(cell);
    L'évolution sera de la faire avec une classe CSS

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

Discussions similaires

  1. [XL-2010] Numéroter lignes et colonnes dans un tableau ou feuille excel
    Par Jacques-Henri dans le forum Excel
    Réponses: 3
    Dernier message: 15/05/2012, 00h10
  2. ajouter des lignes et colonnes dans un tableau
    Par sky88 dans le forum Débuter
    Réponses: 1
    Dernier message: 03/12/2008, 18h04
  3. Figer des lignes et des colonnes dans un tableau
    Par Opo dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 15/11/2006, 16h10
  4. insertion dynamique de lignes dans un tableau
    Par loreleï85 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 22/06/2006, 17h32
  5. Réponses: 9
    Dernier message: 19/12/2005, 14h24

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