redirection et listes dynamiques liées

Eléphant du PHP | 254 Messages

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.
<?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 !
:wink:

ViPHP
ViPHP | 656 Messages

17 févr. 2006, 12:56

/* 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 */ 
Déja tu a faux la dessus. persistante signifie que même ton script fini, la connection reste active.

Même si tu refait une requête plus tard, utilise mysql ou mysqli_connect()

http://fr3.php.net/manual/fr/function.m ... onnect.php

Aussi on se demande ou tu a pris tes meta tags :P

Moi je n'arrive pas a voir ou est ce que tu definit la variable $idr
Modifié en dernier par Ultiny le 17 févr. 2006, 13:00, modifié 1 fois.

ViPHP
ViPHP | 656 Messages

17 févr. 2006, 12:59

Pardon j'avais pas vu.

Peut tu nous donner la structure SQL s'il te plaît.

Eléphant du PHP | 254 Messages

17 févr. 2006, 13:50

oui j'ai repris, la page de la FAQ listes déroulantes, d'où l'existance des tags....que je n'ai pas encore modifiés.

structure de la base :

Produits
ID
id_type
id_marque
.....

type
id_type
categorie

marque
id_marque
marque

La connexion pconnect avait été établie pour la FAQ.
Dois-je la modifier pour mon utilisation ?
Merci

je remets le code un peu modifié
<?php 
/* 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="" /> 
<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']; ?>&bouton=Rechercher">

<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> 
Voila l'erreur que j'ai, une fois validée la recherche :
...home/recherche.php?VARcategorie=1&VARmarque=<b>Notice</b>:Undefined index:VARmarque in <b>...menu2.php on line<b>114</b>&bouton=Rechercher

Ligne :
...&VARmarque=<?php echo $_POST['VARmarque']; ?> 

Eléphant du PHP | 254 Messages

17 févr. 2006, 17:18

personne pour m'aider ?
:( Merci ! :wink:

Eléphant du PHP | 254 Messages

23 févr. 2006, 16:23

grâce à l'utilisation du même menu, mais en méthode Javascript-Ajax !
cf. mon topic
Merci de votre aide.

Mammouth du PHP | 19672 Messages

24 févr. 2006, 16:44

Tiens, j'ai trouvé ce tuto qui offre des liens, il y a même un démo sur trois listes qui fonctionne très bien, tu y trouveras peut-être bien ton bonheur :-k
Codez en pensant que celui qui maintiendra votre code est un psychopathe qui connait votre adresse :axe:

Eléphant du PHP | 254 Messages

24 févr. 2006, 19:30

je mets le lien en favoris, ça peut servir pour un formulaire !
En fait, je suis arrivée à faire fonctionner ma boite de recherche, tout marche bien merci !
J'ai posté un sujet CSS http://www.phpfrance.com/forums/voir_sujet-15015.php j'ai vu que tu es spécialiste ;-), j'ai fait comme pour ton CV, mais je n'arrive pas à orienter ma page en paysage.... :(

Eléphant du PHP | 95 Messages

30 mars 2006, 10:20

Bonjour,

Je suis confronté au même problème que Coxine mais le tuto mentionné plus haut en AJAX ne me semble pas satisfaisant car il ne permet que les navigateurs Firefox et Internet Explorer, ce qui n'est pas top vous en conviendrez, surtout quand on fait un site grand public et que l'on a de nombreux visiteurs sous Safari ou Opéra (sans parler de ceux qui naviguent encore avec Netscape 4.7) !

Le problème dans les listes déroulantes liées, c'est que très souvent on ne laisse pas les internautes sur la même page (formulaire d'enregistrement etc.). La FAQ n'envisage pas ce problème...

Par ailleurs la solution Javascript est, je suis d'accord avec Coxine, trop complexe pour ceux qui ne sont pas des développeurs avancés en Javascript.

Bref, n'y a-t-il pas un moyen simple de récupérer le choix des utilisateurs via des champs cachés dans un formulaire comprenant uniquement le bouton "envoyez" (+ les 2 champs cachés bien sûr!) et permettant de diriger les utilisateurs vers la 2e page ?

Qu'en pensez-vous ? Est-ce faisable ?
Je veux apprendre !!

Eléphant du PHP | 96 Messages

30 mars 2006, 11:40

Bref, n'y a-t-il pas un moyen simple de récupérer le choix des utilisateurs via des champs cachés dans un formulaire comprenant uniquement le bouton "envoyez" (+ les 2 champs cachés bien sûr!) et permettant de diriger les utilisateurs vers la 2e page ?
Bonjour, moi aussi j'ai le même probléme...une idée ?

Eléphant du PHP | 95 Messages

31 mars 2006, 17:04

Je n'ai pas résolu ce problème qui semble embarrasser bon nombre de développeurs mais je l'ai contourné.

Ma solution n'est valable que si le formulaire ne contient que les listes déroulantes liées... J'ai ajouté une 3e combo-box dans laquelle apparaissent les résultats de ma recherche et j'ai ajouté tout simplement l'événement javascript onChange :
<select onchange="document.location=this.options[this.selectedIndex].value" name="intitule" id="intitule">
<option>Choisissez pour ouvrir la fiche ---</option>
...
<option value="page_detail.php?id=<?php echo $row_fx1['id']; ?>"<?php if (!(strcmp($row_fx1['id'], @$_POST['mavar']))) {echo "selected=\"selected\"";} ?>><?php echo $row_1['intitule']?></option>
...
Je veux apprendre !!