Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > JavaScript
JavaScript Forum programmation JavaScript. Lire : Cours JavaScript, FAQ JavaScript, Toutes les FAQ JavaScript et Sources JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 28/11/2011, 17h33   #1
Membre régulier
 
Avatar de Baldy
 
Homme
Inscription : juin 2008
Messages : 192
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 28
Localisation : France

Informations forums :
Inscription : juin 2008
Messages : 192
Points : 89
Points : 89
Par défaut Cacher/Afficher une ligne de tableau

Bonjour

J'ai le code JS suivant :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
function cacher(){
			var champs = document.getElementsByTagName('input');
			for(var i=0;i<champs.length;i++) {
				var c = champs[i];
				if(c.type.toLowerCase( )== 'checkbox' && c.name == 'demi' && c.checked){
					document.getElementById('test').style.display = "block";
				}
				else{
					document.getElementById('test').style.display = "none";
				}
			}
		}
Normalement il me permet de cacher/afficher la ligne d'un tableau lorsque je coche/décoche une checkbox :

Code :
1
2
3
4
5
6
7
...
matin <input type="checkbox" name="demi" value="matin" onClick="javascript:cacher();" /> apr&egrave;s-midi <input type="checkbox" name="demi" value="am" onClick="javascript:cacher();" />
						</td>
					</tr>
					<tr id="test">
						<td>Date de fin</td>
...
Le fait de cocher une case me cache bien la ligne. Par contre le fait de la décocher n'affiche pas à nouveau la ligne.

Que faut-il faire?

Merci
Baldy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/11/2011, 18h41   #2
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 808
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

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

Informations forums :
Inscription : juin 2008
Messages : 13 808
Points : 35 789
Points : 35 789
Code :
document.getElementById('test').style.display = "block";
Le display d'une balise <tr> ,'est pas block mais table-row, qui n'est pas reconnu par tous les navigateurs.
Le plus simple est d'attribuer une chaine vide qui rétablira la valeur par défaut :
Code :
document.getElementById('test').style.display = "";
Ceci dit, je doute fort que le code fonctionne si tu coches le premier checkbox...
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, 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
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/11/2011, 08h38   #3
Membre régulier
 
Avatar de Baldy
 
Homme
Inscription : juin 2008
Messages : 192
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 28
Localisation : France

Informations forums :
Inscription : juin 2008
Messages : 192
Points : 89
Points : 89
Le fait de mettre une chaîne vide ne change rien, la ligne du tableau ne s'affiche toujours pas. Même chose avec "table-row".

Du coup je me demande si il faudrait que je cache autre chose que le TR du tableau ...
Baldy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/11/2011, 10h35   #4
Rédacteur/Modérateur
 
Avatar de bigboomshakala
 
Homme
Ingénieur développement logiciels
Inscription : avril 2004
Messages : 2 051
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 32
Localisation : France

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

Informations forums :
Inscription : avril 2004
Messages : 2 051
Points : 2 425
Points : 2 425
mets des alert() dans ton code et tu comprendras tout de suite le problème

ta ligne ne réapparaîtra que si tu coches les 2 checkbox
__________________
Modérateur/Rédacteur

Tutoriels/Articles :
- Espace de noms (ou namespace) en JavaScript
- Créer une table HTML éditable en JavaScript (nouveau)
- Smile.Fx : Bibliothèque d'effets visuels en JavaScript (en cours - démo disponible)

mon espace
bigboomshakala est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/11/2011, 10h45   #5
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 808
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

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

Informations forums :
Inscription : juin 2008
Messages : 13 808
Points : 35 789
Points : 35 789
Reste aussi à savoir si "test" est bien un id unique dans la page.
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, 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
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/11/2011, 10h51   #6
Membre régulier
 
Avatar de Baldy
 
Homme
Inscription : juin 2008
Messages : 192
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 28
Localisation : France

Informations forums :
Inscription : juin 2008
Messages : 192
Points : 89
Points : 89
On m'avait que les tableaux HTML c'était le démon!

Finalement j'ai revu ma mise en page, j'utilise maintenant les P et DIV et évidemment ça marche beaucoup mieux.

Je vous ai embêté pour rien.
Baldy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/11/2011, 11h19   #7
Rédacteur/Modérateur
 
Avatar de bigboomshakala
 
Homme
Ingénieur développement logiciels
Inscription : avril 2004
Messages : 2 051
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 32
Localisation : France

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

Informations forums :
Inscription : avril 2004
Messages : 2 051
Points : 2 425
Points : 2 425
je ne suis pas certain que tu ais compris l'erreur. ça n'est pas une question de tableau démoniaque.

tu boucles sur tous les checkbox "demi" de la page et tu affiches la ligne si le checkbox est checké, sinon tu masques la ligne. ton code s'applique chaque fois aux 2 checkbox... le display de la ligne est modifiée 2 fois à chaque sélection/désélection de checkbox (par exemple une fois pour faire afficher la ligne et une fois pour la masquer direct derrière. donc tu as l'impression qu'elle ne réapparait jamais)
__________________
Modérateur/Rédacteur

Tutoriels/Articles :
- Espace de noms (ou namespace) en JavaScript
- Créer une table HTML éditable en JavaScript (nouveau)
- Smile.Fx : Bibliothèque d'effets visuels en JavaScript (en cours - démo disponible)

mon espace
bigboomshakala est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h12.


 
 
 
 
Partenaires

Hébergement Web