Forum |  HardWare.fr | News | Articles | PC | S'identifier | S'inscrire | Shop Recherche
1531 connectés 

  FORUM HardWare.fr
  Programmation
  PHP

  [resolu] Liste dynamiques liées, pb de récupération de variable

 



 Mot :   Pseudo :  
 
Bas de page
Auteur Sujet :

[resolu] Liste dynamiques liées, pb de récupération de variable

n°1308218
coxine
Posté le 17-02-2006 à 16:55:56  profilanswer
 

Bonjour
 
Voilà, j'ai effectué, d'après une tuto, une boite de recherche de listes dynamiques liées.
Dans ma base, j'ai des types, des marques.
Je souhaite, si je sélectionne le type1, que les marques1 soit ouvertes dans une autre boite.
Idem pour type2 / marque2 etc....
La sélection des types/marque fonctionne.
Je souhaite arriver sur une page résultats : recherche.php
J'arrive à vérifer la variable TYPE, appelée VARcategorie, mais pas la variable MARQUE, appelée VARmarque.
§Je vous copie le code, merci de bien vouloir m'aider !  :jap:  :)  
 

Code :
  1. <?php
  2. echo("<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n" );
  3. /* Variables de connexion : ajustez ces paramètres selon votre propre environnement */
  4. $serveur = "localhost";
  5. $admin   = "root";
  6. $mdp     = "";
  7. $base    = "base";
  8. /* On récupère si elle existe la valeur de la région envoyée par le formulaire */
  9. $idr = isset($_POST['VARcategorie'])?$_POST['VARcategorie']:null;
  10. ?>
  11. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  
  12. <head>
  13. <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" xml:lang="fr" />
  14. <title>Sélectionner un marque selon la catégorie choisie</title>
  15. <link href="includes/style.css" rel="stylesheet" type="text/css" />
  16. </head>
  17. <body style="font-family: verdana, helvetica, sans-serif; font-size: 85%">
  18. <h3 class="Style4">Rechercher</h3>
  19. <?php
  20. /* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()  
  21. *  car on aura besoin de la connexion un peu plus loin dans le script */
  22. $connexion = mysql_connect($serveur, $admin, $mdp);
  23. if($connexion != false)
  24. {
  25.     $choixbase = mysql_select_db($base, $connexion);
  26.     $sql1 = "SELECT `id_type`, `categorie`".
  27.     " FROM `type`".
  28.     " ORDER BY `id_type`";
  29.     $rech_regions = mysql_query($sql1);
  30.     $code_region = array();
  31.     $region = array();
  32.     /* On active un compteur pour les régions */
  33.     $nb_regions = 0;
  34.     if($rech_regions != false)
  35.     {
  36.         while($ligne = mysql_fetch_assoc($rech_regions))
  37.         {
  38.             array_push($code_region, $ligne['id_type']);
  39.             array_push($region, $ligne['categorie']);
  40.             /* On incrémente de compteur */
  41.             $nb_regions++;
  42.         }
  43.     }
  44.     ?> <table width="200" border="1">
  45.   <tr>
  46.     <td><form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgdept"> 
  47. <select name="VARcategorie" class="liste" id="VARcategorie" onchange="document.forms['chgdept'].submit();">
  48.   <option value="-1" selected="selected">- - - Choisissez une catégorie - - -</option>
  49.     <?php
  50.     for($i = 0; $i < $nb_regions; $i++)
  51.     {
  52. ?>
  53.   <option value="<?php echo($code_region[$i]); ?>"<?php echo((isset($idr) && $idr == $code_region[$i])?" selected=\"selected\"":null); ?>><?php echo($region[$i]); ?></option>
  54. <?php
  55.     }
  56.     ?>
  57. </select>
  58.     <?php
  59.     mysql_free_result($rech_regions);
  60.     /* 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 */
  61.     if(isset($idr) && $idr != -1)
  62.     {
  63.         /* Cération de la requête pour avoir les départements de cette région */
  64.         $sql2 = "SELECT `id_marque`, `marque`".
  65.         " FROM `marque`".
  66.         " WHERE `id_type` = ". $idr ."".
  67.         " ORDER BY `marque`;";
  68.         if($connexion != false)
  69.         {
  70.             $rech_dept = mysql_query($sql2, $connexion);
  71.             /* Un petit compteur pour les départements */
  72.             $nd = 0;
  73.             /* On crée deux tableaux pour les numéros et les noms des départements */
  74.             $code_dept = array();
  75.             $nom_dept = array();
  76.             /* On va mettre les numéros et noms des départements dans les deux tableaux */
  77.             while($ligne_dept = mysql_fetch_assoc($rech_dept))
  78.             {
  79.                 array_push($code_dept, $ligne_dept['id_marque']);
  80.                 array_push($nom_dept, $ligne_dept['marque']);
  81.                 $nd++;
  82.             }
  83.             /* Maintenant on peut construire la liste déroulante */
  84.             ?><br />
  85. <select name="VARmarque" class="liste" id="VARmarque">
  86.             <?php
  87.             for($d = 0; $d<$nd; $d++)
  88.             {
  89.                 ?>
  90.   <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>
  91.                 <?php
  92.             }
  93. ?>
  94. </select>
  95. <?php
  96.         }
  97.         /* Un petit coup de balai */
  98.         mysql_free_result($rech_dept);
  99.     }
  100. ?>
  101. </form></td>
  102.   </tr>
  103.   <tr>
  104.     <td><form id="form1" method="post" action="home/recherche.php?VARcategorie=<?php echo $_POST['VARcategorie']; ?>&amp;VARmarque=<?php echo $_POST['VARmarque']; ?>&amp;bouton=Rechercher">
  105. <input name="VARcategorie" type="hidden" id="VARcategorie" value="<?php echo $_POST['VARcategorie']; ?>" />
  106.   <input name="VARmarque" type="hidden" id="VARmarque" value="<?php echo $_POST['VARmarque']; ?>" />
  107.   <input name="ok" type="submit" id="ok" value="Envoyer" />
  108. </form> </td>
  109.   </tr>
  110. </table>
  111. <?php
  112.     /* Terminé, on ferme la connexion */
  113.     mysql_close($connexion);
  114. }
  115. else
  116. {
  117.     /* Si on arrive là, c'est pas bon signe, il faut vérifier les  
  118.     * paramètres de connexion, mot de passe, serveur pas démarré etc... */
  119. ?>
  120. <p>Un incident s'est produit lors de la connexion à la base de données, veuillez essayer à nouveau ultérieurement.</p>
  121. <?php
  122. }
  123. ?>
  124. </body>
  125. </html>


Message édité par coxine le 23-02-2006 à 15:19:24
mood
Publicité
Posté le 17-02-2006 à 16:55:56  profilanswer
 

n°1308534
erel69
Posté le 18-02-2006 à 11:17:19  profilanswer
 

Code :
  1. /* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()  
  2. *  car on aura besoin de la connexion un peu plus loin dans le script */
  3. $connexion = mysql_connect($serveur, $admin, $mdp);


 
Pas bien de mentir  :na:


Message édité par erel69 le 18-02-2006 à 11:57:51

---------------
France Hardware | Degroup Test | Degroup News
n°1308535
erel69
Posté le 18-02-2006 à 11:18:05  profilanswer
 

Code :
  1. <form id="form1" method="post" action="home/recherche.php?VARcategorie=<?php echo $_POST['VARcategorie']; ?>&amp;VARmarque=<?php echo $_POST['VARmarque']; ?>&amp;bouton=Rechercher">
  2. <input name="VARcategorie" type="hidden" id="VARcategorie" value="<?php echo $_POST['VARcategorie']; ?>" />
  3. <input name="VARmarque" type="hidden" id="VARmarque" value="<?php echo $_POST['VARmarque']; ?>" />
  4. <input name="ok" type="submit" id="ok" value="Envoyer" />
  5. </form>


 
Pourquoi tu passes en GET ce que tu passes déjà en POST ?
 
 
Et un petit conseil, n'hésite pas à utiliser les affichages en php, là tu alternes beaucoup trop le code php et le code html, c'est un peu illisible.
 
Exemple :
 

Code :
  1. ?>
  2. <option value="<?php echo($code_region[$i]); ?>"<?php echo((isset($idr) && $idr == $code_region[$i])?" selected=\"selected\"":null); ?>><?php echo($region[$i]); ?></option>
  3. <?php


 
Tu aurais pu faire
 

Code :
  1. echo '<option value="'.$code_region[$i].'"'.( (isset($idr) && $idr == $code_region[$i]) ? ' selected="selected" ' : '' ).'>'.$region[$i].'</option>';

Message cité 2 fois
Message édité par erel69 le 18-02-2006 à 11:57:53

---------------
France Hardware | Degroup Test | Degroup News
n°1308539
coxine
Posté le 18-02-2006 à 11:32:42  profilanswer
 

erel69 a écrit :

Code :
  1. <form id="form1" method="post" action="home/recherche.php?VARcategorie=<?php echo $_POST['VARcategorie']; ?>&amp;VARmarque=<?php echo $_POST['VARmarque']; ?>&amp;bouton=Rechercher">
  2. <input name="VARcategorie" type="hidden" id="VARcategorie" value="<?php echo $_POST['VARcategorie']; ?>" />
  3. <input name="VARmarque" type="hidden" id="VARmarque" value="<?php echo $_POST['VARmarque']; ?>" />
  4. <input name="ok" type="submit" id="ok" value="Envoyer" />
  5. </form>


 
Pourquoi tu passes en GET ce que tu passes déjà en POST ?


Bonjour, merci d'avoir regardé mon pb.
Oups, comme ce script vient d'un tuto, je n'ai pas modifié les commentaires, la connection était pconnect, j'ai préféré la passer en connect, suite à des conseils. Mais peut-être ai-je fait fausse route ?
J'avoue que je suis un peu perdu sur l'utilisation des transmissions de variables en métode POST ou GET.
Faut-il que j'ajoute des variables de sessions ?
Que me conseillerais-tu comme commande dans l'envoi de mon formulaire ? :whistle:  
Merci ! :jap:


Message édité par coxine le 18-02-2006 à 11:33:30
n°1308540
coxine
Posté le 18-02-2006 à 11:45:59  profilanswer
 

erel69 a écrit :

Code :
  1. Tu aurais pu faire
  2. [cpp]
  3. echo '<option value="'.$code_region[$i].'"'.( (isset($idr) && $idr == $code_region[$i]) ? ' selected="selected" ' : '' ).'>'.$region[$i].'</option>';



Merci, je viens de mettre en pratique, tu as raison, le code devient fouilli !

n°1308546
erel69
Posté le 18-02-2006 à 11:56:16  profilanswer
 

Pour le pconnect c'était juste pour titiller :) J'utilises aussi mysql_connect :)
 
Tu pourrais utiliser des variables de sessions, mais ce n'est pas la peine.
 
En fait, si j'ai bien lu, tu as deux formulaires :
- Le premier renvoyant sur la page courante, pour sélectionner la catégorie et la marque
- Le second envoyant vers la page de recherche
 
Si j'ai bien compris, tu effectues ta recherche ssi tu as la catégorie et la marque ?
Alors pourquoi ne pas faire qu'un formulaire ?
 
Exemple :
 

Code :
  1. <form action="?" method="post">
  2. <select name="catégorie" onchange="this.form.submit();">
  3. ...
  4. </select>
  5. // après ton traitement pour récupérer les marques
  6. <select name="marque">
  7. ...
  8. </select>
  9. ...
  10. </form>


 
Et dans ta page, tu peux très bien faire quelque chose du genre :
 

Code :
  1. $id_cat = ....;
  2. $id_marque = ...;
  3. // avec des verifications si tu as envie
  4. if( $id_cat && $id_marque )
  5.    include 'recherche.php';
  6. else
  7.     ....

Message cité 1 fois
Message édité par erel69 le 18-02-2006 à 11:59:07

---------------
France Hardware | Degroup Test | Degroup News
n°1308580
coxine
Posté le 18-02-2006 à 13:05:55  profilanswer
 

erel69 a écrit :


Si j'ai bien compris, tu effectues ta recherche ssi tu as la catégorie et la marque ?
Alors pourquoi ne pas faire qu'un formulaire ?
Exemple :
    ....
[/cpp]


 
Alors, voilà pourquoi, j'ai été à la recherche de ce tuto chez dans un forum de copains ;-), car au départ j'avais ça :  
un formulaire, avec une liste dynamique allant chercher dans ma base, les types, et ensuite, une autre liste dynamique, allant chercher TOUTES les marques.
En fait je souhaite n'afficher que les marques qui correspondent à la catégorie choisie.

n°1308587
erel69
Posté le 18-02-2006 à 13:17:47  profilanswer
 

Tu peux bien faire cela en un seul formulaire, ce sont les <option> du select qui changent


---------------
France Hardware | Degroup Test | Degroup News
n°1312342
coxine
Posté le 23-02-2006 à 15:18:04  profilanswer
 

erel69 a écrit :

Tu peux bien faire cela en un seul formulaire, ce sont les <option> du select qui changent


Merci de ton aide ! Cela fonctionne nickel !!!


Aller à :
Ajouter une réponse
  FORUM HardWare.fr
  Programmation
  PHP

  [resolu] Liste dynamiques liées, pb de récupération de variable

 

Sujets relatifs
[VBScript] [RESOLU] difference entre winNT et LDAPDeclarer des fonctions avec des noms dynamiques
Est ce que l'on peut faire passer une variable avec un header ?[Resolu] A la quete de '** glibc detected ** free()'
[résolu]Socket non bloquants[résolu]lecture tags id3v2
[RESOLU] problème de conditionfaire une liste avec SQL
Expression reguliere dans une variable...[resolu] Plugin Visual Editor ne fonctionne pas.
Plus de sujets relatifs à : [resolu] Liste dynamiques liées, pb de récupération de variable


Copyright © 1997-2018 Hardware.fr SARL (Signaler un contenu illicite / Données personnelles) / Groupe LDLC / Shop HFR