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 :

Remplacer une ligne de tableau par une autre


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    5
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5
    Par d�faut Remplacer une ligne de tableau par une autre
    Bonjour,

    Je cherche � afficher/masquer des lignes de tableau HTML. En fait � remplacer une ligne affich�e par une autre. Mon code est le suivant :

    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
     
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <script>
    function cache(idElement) {
    	document.getElementById(idElement).style.display = "none";
    	document.getElementById(idElement).style.visibility="hidden";
    }
     
    function affiche(idElement) {
    	document.getElementById(idElement).style.display = "block";
    	document.getElementById(idElement).style.visibility="visible";
    }
    </script>
    <body>
    <table border="1">
    <tr><td>0</td><td>&nbsp;</td></tr>
    <tr id="ligne1"><td>1</td><td><input type="button" onclick="affiche('ligne2');cache('ligne1');"></td></tr>
    <tr id="ligne2" style="display:none;visibility:hidden;"><td>2</td><td><input type="button" onclick="affiche('ligne1');cache('ligne2');"></td></tr>
    <tr id="ligne3"><td>3</td><td><input type="button" onclick="affiche('ligne4');cache('ligne3');"></td></tr>
    <tr id="ligne4" style="display:none;visibility:hidden;"><td>4</td><td><input type="button" onclick="affiche('ligne3');cache('ligne4');"></td></tr>
    </table>
    <br>
    </body>
    </html>
    �a ne fonctionne pas correctement sous Firefox et Chrome et je ne comprends pas pourquoi : les deux <td> de mon <tr> sont fusionn�s en un seul au moment de l'affichage.
    Pire : �a fonctionne correctement sous IE8 ce qui me fend le coeur...

    Pourriez-vous m'aider ?

  2. #2
    Membre Expert
    Avatar de RomainVALERI
    Homme Profil pro
    POO�te
    Inscrit en
    Avril 2008
    Messages
    2 652
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 48
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activit� : POO�te

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Par d�faut
    Dans la fonction affiche, essaie d'assigner une chaine vide plutot que "block" � l'�l�ment : il reprendra alors sa valeur par d�faut, ce qui permet d'�viter des surprises de mise en page � cause d'�l�ments inline � qui on attribuerait un display:block...

  3. #3
    R�dacteur

    Avatar de Bovino
    Homme Profil pro
    D�veloppeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activit� : D�veloppeur Web
    Secteur : High Tech - �diteur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par d�faut
    Le display par d�faut d'un tr n'est pas block mais table-row, d'o� l'erreur d'affichage, sauf pour IE qui ne reconnait pas cette valeur

    La meilleure solution est de remplacer 'block' par '' ce qui affecte la valeur par d�faut :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    function cache(idElement) {
        document.getElementById(idElement).style.display = "none";
        document.getElementById(idElement).style.visibility="hidden";
    }
     
    function affiche(idElement) {
        document.getElementById(idElement).style.display = "";
        document.getElementById(idElement).style.visibility="visible";
    }
    D'autre part, coupler visibility et display n'est pas trop judicieux... ils n'ont pas le m�me comportement.
    Tu devrais te limiter � display :
    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
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <script>
    function cache(idElement) {
        document.getElementById(idElement).style.display = "none";
    }
     
    function affiche(idElement) {
        document.getElementById(idElement).style.display = "";
    }
    </script>
    <body>
    <table border="1">
    <tr><td>0</td><td>&nbsp;</td></tr>
    <tr id="ligne1"><td>1</td><td><input type="button" onclick="affiche('ligne2');cache('ligne1');"></td></tr>
    <tr id="ligne2" style="display:none;"><td>2</td><td><input type="button" onclick="affiche('ligne1');cache('ligne2');"></td></tr>
    <tr id="ligne3"><td>3</td><td><input type="button" onclick="affiche('ligne4');cache('ligne3');"></td></tr>
    <tr id="ligne4" style="display:none;"><td>4</td><td><input type="button" onclick="affiche('ligne3');cache('ligne4');"></td></tr>
    </table>
    <br>
    </body>
    </html>
    Pas de question technique par MP !
    Tout le monde peut participer � developpez.com, vous avez une id�e, contactez-moi !
    Mes formations video2brain : La formation compl�te sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'int�gration de JSFiddle et CodePen sur le forum

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    5
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5
    Par d�faut
    Merci � tous les deux pour vos r�ponses.
    J'ai corrig� mon script et il fonctionne.

+ R�pondre � la discussion
Cette discussion est r�solue.

Discussions similaires

  1. Membre calcule par une dimension et pas par les autres
    Par nidhal fekih dans le forum SSAS
    R�ponses: 0
    Dernier message: 13/11/2013, 17h19
  2. [VxiR2] Concat�n� des lignes de tableau en une ligne avec ,
    Par DevFranck dans le forum Webi
    R�ponses: 1
    Dernier message: 05/04/2011, 15h53
  3. R�ponses: 12
    Dernier message: 08/04/2010, 11h45
  4. [MySQL] Recherche fonction donnant tableau d'une ligne du r�sultat d'une requ�te
    Par zakuli dans le forum PHP & Base de donn�es
    R�ponses: 4
    Dernier message: 09/02/2009, 18h56
  5. convertir un tableau en une liste sans passer par une boucle
    Par sallemel dans le forum Collection et Stream
    R�ponses: 7
    Dernier message: 04/12/2008, 22h04

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