Précédent   Forum des professionnels en informatique > PHP > Langage > Formulaires
Formulaires Forum d'entraide sur les formulaires avec PHP. Avant de poster -> FAQ formulaires, Cours de formulaires et Sources de formulaires
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 21/05/2007, 12h04   #1
Membre actif
 
Avatar de JmL40
 
Inscription : mai 2007
Messages : 310
Détails du profil
Informations personnelles :
Âge : 26

Informations forums :
Inscription : mai 2007
Messages : 310
Points : 191
Points : 191
Envoyer un message via MSN à JmL40
Par défaut Deux Liste déroulantes : Récuperer le choix de la première dans la deuxième

Bonjour,

J'explique le problème !

J'ai deux liste déroulantes et la deuxième liste détroulantes dépend du choix de la première. J'ai essayé d'implémenter quelque chose de passable je pense, mais cela ne fonctionne pas, du moins en partir !

En résumé, je n'arrive pas a récupérer le choix de la première liste dans la deuxième liste.

Je vous fournis le code :

Code :
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
66
67
68
69
70
71
72
73
74
75
76
77
 
<html>
 
	<head>
 
	</head>
 
	<body>
 
	<?php
		// information pour la connection à le DB
		$host = 'localhost';
		$user = 'root';
		$pass = '';
		$db = 'masdb';
 
		// connection à la DB
		$link = mysql_connect ($host,$user,$pass) or die ('Erreur : '.mysql_error() );
		mysql_select_db($db) or die ('Erreur :'.mysql_error());	
	?>
 
	<form method="post" action="filtre.php"> 
	<p><FONT face="Arial" size="1"><strong><u> Filtre 1</u></strong></font><a></p>
 
		<p>		
		    <select name="filtre1" size="1">
 
			        <option value="NomLignee"> Nom Lignee </option>
			        <option value="ObtenteurLig"> Obtenteur </option>
			        <option value="MainteneurLig"> Mainteneur </option>
					<option value="OrigGenetiqueLig"> Origine Genetique </option>
					<option value="FamOrigineLig"> Famille Origine </option>
					<option value="PriveeLig"> Privee </option>
					<option value="CatalogueLig"> Catalogue </option>
					<option value="NomExtLig"> Nom Extérieur </option>
					<option value="DeNomOffLig"> Denomination Off </option>
					<option value="NomminationLig"> Nommination </option>
					<option value="BreederLig"> Breeder </option>
					<option value="UCFLig"> UCF </option>
					<option value="UCMLig"> UCM </option>
					<option value="RecurrentLig"> Recurrent</option>
					<option value="Caractere"> Nommination </option>
					<option value="CodeObtenteuro">Code Obtenteur </option>
					<option value="Nomo"> Nom Obtenteur </option>
 
			</select>		 
		</p>		  
		<p class="bouton"><input type= "submit" value="Afficher Résultat" /></p>
 
	<form method="post" action="filtre.php">
	<p><FONT face="Arial" size="1"><strong><u> Filtre 1</u></strong></font><a></p>
 
		<p>		
		    <select name="filtre1" size="1">
 
			     <?php 
 
						if(isset($_POST['filtre1'])){
 
						$Choix1 = $_POST['filtre1'];
 
						$données = 'SELECT '.$choix1.' FROM TbLigIdentite';
 
						$res = mysql_query($données,$link);
 
							while($val=mysql_fetch_array($res)) {
							echo '<option value ="'.$val["'.$choix1.'"].'">'.$val["'.$choix1.'"].'</td>';			 
 
							}				
						}
				?>					
			</select>		  
			</p>		  
		<p class="bouton"><input type= "submit" value="Afficher Résultat" /></p>
</body>
 
</html>
Si quelqu'un peut m'aider !!!

JE VOUS REMERCIE
JmL40 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/05/2007, 13h01   #2
Membre confirmé
 
Inscription : avril 2007
Messages : 254
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 254
Points : 262
Points : 262
Quatres remarques:
1 J'évite d'utiliser des caractères accentués pour les noms de variables.
2 La balise option de ton deuxième n'est pas fermée.
3 Je ne change pas la case des variables $Choix1 et $choix1
4 La balise fermante </td> se trouve dans le while

Que donne l'écho de $_POST['filtre1']?
Ouach est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/05/2007, 13h21   #3
Membre actif
 
Avatar de JmL40
 
Inscription : mai 2007
Messages : 310
Détails du profil
Informations personnelles :
Âge : 26

Informations forums :
Inscription : mai 2007
Messages : 310
Points : 191
Points : 191
Envoyer un message via MSN à JmL40
Ok merci pour les remarques, j'ai supprimer les modifications que j'avais effectuée pour présenter le code que j'essaye de modifier !

L'echo du post retourne bien le choix effectué dans la première liste deroulante: je sélectionne NomLignee, je fais mon echo du poste j'obtiens nomlignee.

Mon problème provient du deuxième formulaire je pense ...

A voir, merci pour l'aide !
JmL40 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/05/2007, 13h44   #4
Membre actif
 
Avatar de JmL40
 
Inscription : mai 2007
Messages : 310
Détails du profil
Informations personnelles :
Âge : 26

Informations forums :
Inscription : mai 2007
Messages : 310
Points : 191
Points : 191
Envoyer un message via MSN à JmL40
J'y suis presque, je récupère bien le premier choix mais apres pour le traitement !

$_POST['filtre1'] recupere le choix du premier formulaire. Je l'exploite ainsi dans mon nouveau formulaire avec :

- La requête :

$données = 'SELECT "'.$_POST['filtre1'].'" FROM TbLigIdentite'; (qui considère le choix du premier formulaire)

- L'affichage en fonction de la requête dans la nouvelle liste :

echo '<option value="'.$val["'.$POST["filtre1"].'"].'">'.$val["'.$POST["filtre1"].'"].'</option>\n';}

C'est cette dernière ligne qui pose problème, aie aie !

J'attends vos suggestions ! MERCI
JmL40 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/05/2007, 14h31   #5
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
Attention tu utilises $POST au lieu de $_POST. Et pour t'éviter les problèmes de simple quote, double quote etc, fais sur plusieurs lignes :

Code :
1
2
3
4
 
$filtre1 = $_POST['filtre1']; 
$maVal = $val[$filtre1 ];
echo '<option value="'.$maVal . '">'. $maVal .'</option>\n';
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/05/2007, 15h22   #6
Membre actif
 
Avatar de JmL40
 
Inscription : mai 2007
Messages : 310
Détails du profil
Informations personnelles :
Âge : 26

Informations forums :
Inscription : mai 2007
Messages : 310
Points : 191
Points : 191
Envoyer un message via MSN à JmL40
Pour ceux que ca interresse, je donne ma solution, qui n'est surement pas la meilleure, mais qui fonctionne.

Code :
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
 
<?php
 
	if (isset($_POST['filtre1'])){
 
    echo '<form method="get" action="filtre.php">';
 
    echo '<select name="filtre2" align = "center" size="1">';
 
		$choix1 = $_POST['filtre1'];
 
		$données = 'SELECT '.$choix1.' FROM TbLigIdentite';
 
		$res = mysql_query($données,$link);
 
		while($val=mysql_fetch_array($res)) {		
 
		echo '<option value="'.$val[$choix1].'">'.$val[$choix1].'</option>\n';}
 
	echo '</select>';  
	echo '</p>'; 
	echo '</form>';	
 
	}
	?>
$choix1 est le résultat du choix dans le premier formulaire !

Merci pour l'aide précieuse Je reviendrai ...
JmL40 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 14h05.


 
 
 
 
Partenaires

Hébergement Web