Récupérer une valeur d'une liste déroulante
Posté : 26 avr. 2013, 10:33
Bonjour,
Voilà j'ai réussi à réaliser une liste déroulante qui, en fonction du choix de l'utilisateur, permet d'afficher une deuxième liste déroulante avec d'autres choix.
Mon soucis est que, bien qu'ayant un petit peu d’expérience en PHP, je n'arrive pas à réaliser l'opération suivante que j'aimerais faire.
Le but est maintenant qu'en fonction de ce que l'utilisateur choisit dans le deuxième menu déroulant, un petit texte s'affiche en dessous des menus déroulant.
Exemple :
Menu 1 : Type de l'association ==> Sportive
Menu 2 : Thème de l'association ==> Tennis
Et là j'aimerais qu'un petit paragraphe, que j'aimerais moi même écrit, apparaisse en dessous. Exemple : Tennis, contactez cette association à l'adresse [email protected] ou au 06 36 36 36 36...
Et quand un autre utilisateur ou même le même change et choisisse poterie par exemple, j'aimerais qu'il y ait un autre texte, destiné à la poterie etc..
En gros que le texte s'adapte au choix de l'utilisateur.
Je pense qu'il faut récupérer une variable de mon code et en suite faire une sorte de if $valeur == "Tennis" { //code du texte} non?..
Voici mon code en question qui fait apparaître deux listes et affiche juste une vérification...
Voilà j'ai réussi à réaliser une liste déroulante qui, en fonction du choix de l'utilisateur, permet d'afficher une deuxième liste déroulante avec d'autres choix.
Mon soucis est que, bien qu'ayant un petit peu d’expérience en PHP, je n'arrive pas à réaliser l'opération suivante que j'aimerais faire.
Le but est maintenant qu'en fonction de ce que l'utilisateur choisit dans le deuxième menu déroulant, un petit texte s'affiche en dessous des menus déroulant.
Exemple :
Menu 1 : Type de l'association ==> Sportive
Menu 2 : Thème de l'association ==> Tennis
Et là j'aimerais qu'un petit paragraphe, que j'aimerais moi même écrit, apparaisse en dessous. Exemple : Tennis, contactez cette association à l'adresse [email protected] ou au 06 36 36 36 36...
Et quand un autre utilisateur ou même le même change et choisisse poterie par exemple, j'aimerais qu'il y ait un autre texte, destiné à la poterie etc..
En gros que le texte s'adapte au choix de l'utilisateur.
Je pense qu'il faut récupérer une variable de mon code et en suite faire une sorte de if $valeur == "Tennis" { //code du texte} non?..
Voici mon code en question qui fait apparaître deux listes et affiche juste une vérification...
<?php
echo("<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n");
/* Variables de connexion : ajustez ces paramètres selon votre propre environnement */
$serveur = "localhost";
$admin = "root";
$mdp = "";
$base = "bdfinale";
/* On récupère si elle existe la valeur du typeAssociation envoyée par le formulaire */
$idr = isset($_POST['typeassociation'])?$_POST['typeassociation']:null;
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" xml:lang="fr" />
<title>Choisissez le type d'une association</title>
<meta name="description" content="Listes déroulantes dynamiques inter-dépendantes" />
<meta name="keywords" content="" />
<meta name="author" content="Cyrano" />
<meta name="generator" content="Zend Studio Environnement et WebExpert 5" />
<meta http-equiv="imagetoolbar" content="no" />
<meta http-equiv="Pragma" content="no-cache" />
</head>
<body style="font-family: verdana, helvetica, sans-serif; font-size: 85%">
<?php
if(isset($_POST['ok']) && isset($_POST['association']) && $_POST['association'] != "")
{
$typeassociation_selectionnee = $_POST['typeassociation'];
$association_selectionne = $_POST['association'];
?>
<p>Vous avez sélectionné l'association <?php echo($association_selectionne); ?> de type <?php echo($typeassociation_selectionnee); ?></p>
<?php
}
?>
<h3>Trouver une association</h3>
<?php
/* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()
* car on aura besoin de la connexion un peu plus loin dans le script */
$connexion = mysql_pconnect($serveur, $admin, $mdp);
if($connexion != false)
{
$choixbase = mysql_select_db($base, $connexion);
$sql1 = "SELECT `id`, `type`".
" FROM `typeassociation`".
" ORDER BY `id`";
$rech_typeassociation = mysql_query($sql1);
$code_typeassociation = array();
$typeassociation = array();
/* On active un compteur pour les type d'associations */
$nb_typeassociation = 0;
if($rech_typeassociation != false)
{
while($ligne = mysql_fetch_assoc($rech_typeassociation))
{
array_push($code_typeassociation, $ligne['id']);
array_push($typeassociation, $ligne['type']);
/* On incrémente le compteur */
$nb_typeassociation++;
}
}
?>
<form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgassociation">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez une type d'Association</legend>
<select name="typeassociation" id="typeassociation" onchange="document.forms['chgassociation'].submit();">
<option value="-1">- - - Aucun - - -</option>
<?php
for($i = 0; $i < $nb_typeassociation; $i++)
{
?>
<option value="<?php echo($code_typeassociation[$i]); ?>"<?php echo((isset($idr) && $idr == $code_typeassociation[$i])?" selected=\"selected\"":null); ?>><?php echo($typeassociation[$i]); ?></option>
<?php
}
?>
</select>
<?php
mysql_free_result($rech_typeassociation);
/* On commence par vérifier si on a envoyé un numéro de région et le cas échéant s'il est différent de -1 */
if(isset($idr) && $idr != -1)
{
/* Cération de la requête pour avoir les associations de ce type d'association */
$sql2 = "SELECT `id`, `nom`".
" FROM `association`".
" WHERE `idType` = ". $idr ."".
" ORDER BY `id`;";
if($connexion != false)
{
$rech_association = mysql_query($sql2, $connexion);
/* Un petit compteur pour les associations */
$nb_association = 0;
/* On crée deux tableaux pour les numéros et les noms des associations */
$code_association = array();
$nom_association = array();
/* On va mettre les numéros et noms des associations dans les deux tableaux */
while($ligne_association = mysql_fetch_assoc($rech_association))
{
array_push($code_association, $ligne_association['id']);
array_push($nom_association, $ligne_association['nom']);
$nb_association++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="association" id="association">
<?php
for($d = 0; $d<$nb_association; $d++)
{
?>
<option value="<?php echo($code_association[$d]); ?>"<?php echo((isset($association_selectionne) && $association_selectionne == $code_association[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_association[$d]." (". $code_association[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_association);
}
?>
<br /><input type="submit" name="ok" id="ok" value="Envoyer" />
</fieldset>
</form>
<?php
/* Terminé, on ferme la connexion */
mysql_close($connexion);
}
else
{
/* Si on arrive là, c'est pas bon signe, il faut vérifier les
* paramètres de connexion, mot de passe, serveur pas démarré etc... */
?>
<p>Un incident s'est produit lors de la connexion à la base de données, veuillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
</body>
</html>