par
thierry222 » 20 août 2008, 08:30
Bonjour,
J'ai utilisé "Listes déroulantes liées" posté dans la rubrique FAQ et tutoriels, je l'ai adapté pour afficher les annonces d'un departement quand celui-ci est sélectionné.
Tout fonctionne sauf un dernier petit probleme que ne n'arrive pas à resoudre:
Quand on a selectionné pour la premiere fois une region toutes les annonces de cette region s'affichent et on peut affiner par departement.
Mais si on selectionne ensuite une autre region, les annonces ne s'affichent plus, il faut d'abord selectionner un departement pour afficher les annonces...
quelqu'un a une idée ?
d'avance merci
<?php
require('gestion/qs_connection.php');
$base = "regions";
if (isset($_REQUEST["region"]))
{
$region= $_REQUEST["region"] ;
$_SESSION['region']=$region;
}
else if (isset($_SESSION['region']))
$region=$_SESSION['region'];
else
$region= 0;
if (isset($_REQUEST["depart"]))
{
$depart= $_REQUEST["depart"] ;
$_SESSION['depart']=$depart;
}
else if (isset($_SESSION['depart']))
$depart=$_SESSION['depart'];
else
$depart= 0;
$idr = isset($_POST['region'])?$_POST['region']:null;
if(isset($_POST['ok']) && isset($_POST['depart']) && $_POST['depart'] != "")
{
$depart=$_POST['depart'];
$region=$_POST['region'];
}
?>
<table cellpadding="0" cellspacing="0">
<tr>
<td width="457" colspan="3" ><p align="left">
<?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($host,$user,$passwd);
if($connexion != false)
{
$choixbase = mysql_select_db($base,$connexion);
$sql1 = "SELECT `idregion`, `libregion`".
" FROM `regions`".
" ORDER BY `idregion`";
$rech_regions = mysql_query($sql1);
$code_region = array();
$region2 = 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['idregion']);
array_push($region2, $ligne['libregion']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?>
<form action="liste_annonces.php " method="post" id="chgdept">
<fieldset style="margin-left:6; margin-right:6; margin-bottom:6; margin-top:6; border:1pxb solid #CCCCCC; background-color:" >
<legend > Votre sélection </legend> <br /><?php RemplirTypeCommerce("typeann"); ?><br />
<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($region2[$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 `iddepart`, `libdepart`".
" FROM `departements`".
" WHERE `id_region` = ". $idr ." ".
" ORDER BY `iddepart`";
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 */
$depart = 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($depart, $ligne_dept['iddepart']);
array_push($nom_dept, $ligne_dept['libdepart']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?><select name="depart" id="depart">
<?php
for($d = 0; $d<$nd; $d++ )
{
?>
<option value="<?php echo($depart[$d]); ?>"<?php echo((isset($dept_selectionne) && $dept_selectionne == $depart[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_dept[$d]); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
}
?>
<br /><br /> <input type="submit" name="ok" value="Modifier" > <br /><br />
</fieldset>
</form>
<?php
/* Je ne peux pas fermer la connexion car j'en ai besoin dans la suite de la page */
}
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></tr>
</table>
Bonjour,
J'ai utilisé "Listes déroulantes liées" posté dans la rubrique FAQ et tutoriels, je l'ai adapté pour afficher les annonces d'un departement quand celui-ci est sélectionné.
Tout fonctionne sauf un dernier petit probleme que ne n'arrive pas à resoudre:
Quand on a selectionné pour la premiere fois une region toutes les annonces de cette region s'affichent et on peut affiner par departement.
Mais si on selectionne ensuite une autre region, les annonces ne s'affichent plus, il faut d'abord selectionner un departement pour afficher les annonces...
quelqu'un a une idée ?
d'avance merci
[php]
<?php
require('gestion/qs_connection.php');
$base = "regions";
if (isset($_REQUEST["region"]))
{
$region= $_REQUEST["region"] ;
$_SESSION['region']=$region;
}
else if (isset($_SESSION['region']))
$region=$_SESSION['region'];
else
$region= 0;
if (isset($_REQUEST["depart"]))
{
$depart= $_REQUEST["depart"] ;
$_SESSION['depart']=$depart;
}
else if (isset($_SESSION['depart']))
$depart=$_SESSION['depart'];
else
$depart= 0;
$idr = isset($_POST['region'])?$_POST['region']:null;
if(isset($_POST['ok']) && isset($_POST['depart']) && $_POST['depart'] != "")
{
$depart=$_POST['depart'];
$region=$_POST['region'];
}
?>
<table cellpadding="0" cellspacing="0">
<tr>
<td width="457" colspan="3" ><p align="left">
<?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($host,$user,$passwd);
if($connexion != false)
{
$choixbase = mysql_select_db($base,$connexion);
$sql1 = "SELECT `idregion`, `libregion`".
" FROM `regions`".
" ORDER BY `idregion`";
$rech_regions = mysql_query($sql1);
$code_region = array();
$region2 = 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['idregion']);
array_push($region2, $ligne['libregion']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?>
<form action="liste_annonces.php " method="post" id="chgdept">
<fieldset style="margin-left:6; margin-right:6; margin-bottom:6; margin-top:6; border:1pxb solid #CCCCCC; background-color:" >
<legend > Votre sélection </legend> <br /><?php RemplirTypeCommerce("typeann"); ?><br />
<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($region2[$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 `iddepart`, `libdepart`".
" FROM `departements`".
" WHERE `id_region` = ". $idr ." ".
" ORDER BY `iddepart`";
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 */
$depart = 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($depart, $ligne_dept['iddepart']);
array_push($nom_dept, $ligne_dept['libdepart']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?><select name="depart" id="depart">
<?php
for($d = 0; $d<$nd; $d++ )
{
?>
<option value="<?php echo($depart[$d]); ?>"<?php echo((isset($dept_selectionne) && $dept_selectionne == $depart[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_dept[$d]); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
}
?>
<br /><br /> <input type="submit" name="ok" value="Modifier" > <br /><br />
</fieldset>
</form>
<?php
/* Je ne peux pas fermer la connexion car j'en ai besoin dans la suite de la page */
}
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></tr>
</table>[/php]