redirection et listes dynamiques liées
Posté : 17 févr. 2006, 11:16
Bonjour à tous,
je poste ici, car je ne trouve pas la solution, et ma question est lus du ressort du PHP que du SQL.
Je me suis servie de la FAQ "listes dynamiques liées", j'ai utilisé la méthode 100% PHP.
Le menu fonctionne bien.
Je souhaiterai l'utiliser comme boite de recherche, donc après avoir sélectionné la catégorie (ds tuto region) et la marque (ds tuto département), on clique pour obtenir les résultats sur la page "recherche.php".
Je dois donc récupérer les variables appelées "VARcategorie" et "VARmarque". Je ne récupère que la catégorie, mais pas la marque.
Je débute, je pense qu'il faut faire une vérif mais je n'y arrive pas. (jusqu'à maintenant, j'utilisais des listes déroulantes dynamiques, mais sans filtre après la sélection catégorie....toutes les marques de ma base s'affichent.
Quelqu'un pour m'aider
Merci beaucoup !

je poste ici, car je ne trouve pas la solution, et ma question est lus du ressort du PHP que du SQL.
Je me suis servie de la FAQ "listes dynamiques liées", j'ai utilisé la méthode 100% PHP.
Le menu fonctionne bien.
Je souhaiterai l'utiliser comme boite de recherche, donc après avoir sélectionné la catégorie (ds tuto region) et la marque (ds tuto département), on clique pour obtenir les résultats sur la page "recherche.php".
Je dois donc récupérer les variables appelées "VARcategorie" et "VARmarque". Je ne récupère que la catégorie, mais pas la marque.
Je débute, je pense qu'il faut faire une vérif mais je n'y arrive pas. (jusqu'à maintenant, j'utilisais des listes déroulantes dynamiques, mais sans filtre après la sélection catégorie....toutes les marques de ma base s'affichent.
<?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 = "base";
/* On récupère si elle existe la valeur de la région envoyée par le formulaire */
$idr = isset($_POST['VARcategorie'])?$_POST['VARcategorie']: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>Sélectionner un marque selon la catégorie choisie</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" />
<link href="includes/style.css" rel="stylesheet" type="text/css" />
</head>
<body style="font-family: verdana, helvetica, sans-serif; font-size: 85%">
<h3 class="Style4">Rechercher</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`, `categorie`".
" FROM `type`".
" ORDER BY `id_type`";
$rech_regions = mysql_query($sql1);
$code_region = array();
$region = array();
/* On active un compteur pour les régions */
$nb_regions = 0;
if($rech_regions != false)
{
while($ligne = mysql_fetch_assoc($rech_regions))
{
array_push($code_region, $ligne['id_type']);
array_push($region, $ligne['categorie']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?> <table width="200" border="1">
<tr>
<td><form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgdept">
<select name="VARcategorie" class="liste" id="VARcategorie" onchange="document.forms['chgdept'].submit();">
<option value="-1" selected="selected">- - - Choisissez une catégorie - - -</option>
<?php
for($i = 0; $i < $nb_regions; $i++)
{
?>
<option value="<?php echo($code_region[$i]); ?>"<?php echo((isset($idr) && $idr == $code_region[$i])?" selected=\"selected\"":null); ?>><?php echo($region[$i]); ?></option>
<?php
}
?>
</select>
<?php
mysql_free_result($rech_regions);
/* 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 départements de cette région */
$sql2 = "SELECT `id_marque`, `marque`".
" FROM `marque`".
" WHERE `id_type` = ". $idr ."".
" ORDER BY `marque`;";
if($connexion != false)
{
$rech_dept = mysql_query($sql2, $connexion);
/* Un petit compteur pour les départements */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_dept = array();
$nom_dept = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_dept = mysql_fetch_assoc($rech_dept))
{
array_push($code_dept, $ligne_dept['id_marque']);
array_push($nom_dept, $ligne_dept['marque']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?><br />
<select name="VARmarque" class="liste" id="VARmarque">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_dept[$d]); ?>"<?php echo((isset($dept_selectionne) && $dept_selectionne == $code_dept[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_dept[$d]); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
}
?>
</form></td>
</tr>
<tr>
<td><form id="form1" method="post" action="home/recherche.php?VARcategorie=<?php echo $_POST['VARcategorie']; ?>&VARmarque=<?php echo $_POST['VARmarque']; ?>">
<input name="VARcategorie" type="hidden" id="VARcategorie" value="<?php echo $_POST['VARcategorie']; ?>" />
<input name="VARmarque" type="hidden" id="VARmarque" value="<?php echo($nom_dept[$d]); ?>" />
<input name="ok" type="submit" id="ok" value="Envoyer" />
</form> </td>
</tr>
</table>
<?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>
Voir mon précédent messagedans le forum : SQL.Quelqu'un pour m'aider
Merci beaucoup !