Page 1 sur 3
Listes déroulantes dynamiques inter-dépendantes
Posté : 25 sept. 2005, 04:12
par arentx
Bonjour a tous,
voila j ai dl le tuto sur les regions puis modifié avec mes references et ca marche nikel
Je voudrai savoir comment ajouter une selection sepplementaire "ville", puis lors ce qu on clic sur "Envoyer", que ca ecrive dans un autre fichier "php" le nom d'une table, que j aurai defini avant (comme les id_region), pour afficher les infos de cette ville.
J'espère avoir été assez clair ...
Merci beaucoup, par avance, de votre aide

Re: Listes déroulantes dynamiques inter-dépendantes
Posté : 25 sept. 2005, 09:36
par Cyrano
...J'espère avoir été assez clair ...
Plus ou moins : tu voudrais rajouter une troisième liste déroulante, c'est ça ?
Je te suggère un tour sur
un tuto sur "les boites <select> fantômes"
Posté : 25 sept. 2005, 14:22
par arentx
Ok ! Merci
mais comment faire pour afficher dans un autre fichier le resultat ????

Posté : 25 sept. 2005, 14:27
par Cyrano
Selon la taille qu'occupent les information et/ou leur degré de confidentialités, tu peux les envoyer en paramètres avec l'url de l'autre fichier. Sinon, tu crée des variables de session que l'autre fichier pourra récupérer.
Posté : 25 sept. 2005, 14:49
par Invité
sry mais je debute en php ...
et tout les site pour debutant reste assez complique pour moi
le tiens de tuto est simple mais dans l ajout d'une boite ca merde ...
j essaye de faire du copier/coller en modifiant le nom de la table mais .... rien
Posté : 25 sept. 2005, 14:52
par Cyrano
Mouais, commencer avec ce système pour apprendre, c'est pas évident, tu t'attaques à un morceau conséquent.
Utilises-tu la version avec ou sans JavaScript ?
Posté : 25 sept. 2005, 15:33
par arentx
la version avec 100% php pas de java
Posté : 25 sept. 2005, 15:49
par Cyrano
Ok, alors ce sera moins compliqué.
Le problème est relativement simple, sauf si tu t'es contenté de faire du copier/coller sans trop comprendre le fonctionnement du système. Lors du premier affichage, on a une seule liste : les régions. On sélectionne une région et la page se recharge lors de l'envoi;
Au chargement, on récupère s'il y en a une la région sélectionnée. Maintenant, tu veux ajouter une liste de villes. Ton formulaire doit donc recharger une nouvelle fois la page en envoyant cette fois-ci deux valeurs: la région ET le département. Tu récupères surtout le département pour effectuer la requête nécessaire pour récupérer la liste des villes correspondantes.
Est-ce que tu visualises ce schéma ou pas du tout ? Si tu ne visualises pas du tout, ça va devenir difficile d'expliquer. Lis bien les commentaires que j'ai mis dans le code du modèle sur deux listes, ils sont aussi importants que le code lui-même.
Posté : 25 sept. 2005, 15:53
par arentx
Apprendre oui...
Surtout c'est exactement ce que je cherche
selection
region => département => ville et quand on clic sur "Envoyer" ca affiche dans "ville.php" les infos de la table correspondant a la ville.
Ex:
PACA => VAR => Toulon
"Envoyer"
ca charge "ville.php" avec les infos de Toulon
et que si c'est Bordeaux ca affiche dans "ville.php" les infos de Bordeaux
Voila ...
Merci si tu trouves ... car pour le moment j ai 1 page par ville et ca commence a faire beaucoup de fichiers ....
Posté : 25 sept. 2005, 15:56
par Cyrano
Ok, mais avant d'afficher la page d'une ville, on va commencer par générer les trois listes successives : où en es-tu actuellement sur ce point ? qu'est-ce qui ne fonctionne pas au juste ? montre éventuellement le code que tu as fait, ce sera beaucoup plus facile de t'indiquer où se trouve l'erreur s'il y en a une.
Posté : 25 sept. 2005, 16:13
par arentx
Code : Tout sélectionner
<?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 = "xavier";
/* On récupère si elle existe la valeur de la région envoyée par le formulaire */
$idr = isset($_POST['region'])?$_POST['region']: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 département selon la région 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" />
</head>
<body style="font-family: verdana, helvetica, sans-serif; font-size: 85%">
<h3>Version 100% PHP</h3>
<p>Vous constaterez qu'il y a un délai de latence entre la sélection et la mise à jour.</p>
<?php
if(isset($_POST['ok']) && isset($_POST['departement']) && $_POST['departement'] != "")
{
$region_selectionnee = $_POST['region'];
$dept_selectionne = $_POST['departement'];
?>
<p>Vous avez sélectionné le département <?php echo($dept_selectionne); ?> dans la région <?php echo($region_selectionnee); ?></p>
<?php
}
?>
<h3>Trouver un département</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_region`, `region`".
" FROM `region`".
" ORDER BY `id_region`";
$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_region']);
array_push($region, $ligne['region']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?>
<form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgdept">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez une région</legend>
<select name="region" id="region" onchange="document.forms['chgdept'].submit();">
<option value="-1">- - - Choisissez une région - - -</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_departement`, `departement`".
" FROM `departement`".
" WHERE `id_region` = ". $idr ."".
" ORDER BY `id_departement`;";
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_departement']);
array_push($nom_dept, $ligne_dept['departement']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="departement" id="departement">
<?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]." (". $code_dept[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
}
?>
<!-- Modifié/ajouter par moi
<?php
mysql_free_result($rech_dept);
/* 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_ville`, `ville`".
" FROM `ville`".
" WHERE `id_ville` = ". $idr ."".
" ORDER BY `id_ville`;";
if($connexion != false)
{
$rech_ville = 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_ville = array();
$nom_ville = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_ville = mysql_fetch_assoc($rech_ville))
{
array_push($code_ville, $ligne_ville['id_ville']);
array_push($nom_ville, $ligne_ville['ville']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="ville" id="ville">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_ville[$d]); ?>"<?php echo((isset($ville_selectionne) && $ville_selectionne == $code_ville[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_ville[$d]." (". $code_ville[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_ville);
}
?>
/ fin de modifié/ajouter par moi-->
<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, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
<p><a href="./index2.php" title="Aller vers la version JavaScript">Aller vers la version JavaScript</a></p>
</body>
</html>
Posté : 25 sept. 2005, 16:17
par Cyrano
Première erreur : regarde la ligne 120 : tu as ouvert un comentaire HTML sans le fermer, résultat, tout le reste du HTML est en commentaire:
Au lieu de
Posté : 25 sept. 2005, 16:19
par arentx
ok je modifie sry
je l ai rajouter vite fait pour toi
Posté : 25 sept. 2005, 16:22
par Cyrano
Ok, ensuite, je comprends mal pourquoi tu identifiela ville par rapoprt à la région et non par rapport au département.
Comment est structurée ta table "ville" ?
Posté : 25 sept. 2005, 16:23
par arentx
comme la dept