IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Valeur dans une liste déroulante différente de l'affichage [PHP 5.4]


Sujet :

Langage PHP

  1. #1
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Juillet 2014
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Cher (Centre)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2014
    Messages : 16
    Points : 10
    Points
    10
    Par défaut Valeur dans une liste déroulante différente de l'affichage
    Bonjour à tous,

    Dans un formulaire contenant une liste déroulante de sélection de noms, cette liste de noms est fournie par une requête qui sélectionne les noms commençant uniquement par une lettre (A, B, C etc...). Lorsque un nom est en plusieurs parties (ex BABIN de LIGNAC), le nom s'affiche en entier dans la liste mais la valeur est uniquement le premier mot (BABIN). Y a-t-il une solution à ce problème que je n'avais pas avant de coder en PDO.
    Mon code.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $nom = $pdo->query("SELECT DISTINCT nom FROM deces_indre WHERE nom LIKE '$lettre%' ORDER BY nom ASC");
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    <form id="formulaire" action="deces_indre.php?lettre=<?php echo $lettre ?>" method="post">
       <?php
          if (isset($_POST['selectnom'])){$id1 = $_POST['selectnom']; echo $id1;}
          else {$id1 = "";}
       ?>
       <select name="selectnom">
           <option value="">Sélectionnez</option>
           <?php
              while($repnom = $nom->fetch(PDO::FETCH_OBJ))
             {
                 $selected = "";
                 if ($id1 == $repnom->nom){$selected = "selected='selected'";}
                 echo '<option value='.$repnom->nom.' '.$selected.'>'.$repnom->nom.'</option>';
             }
             $nom->closeCursor();
          ?>
       </select>
       <input type="submit" value="Rechercher">
    </form>
    Merci de votre aide

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    1/ il ne faut pas oublier les double-quotes " :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                 echo '<option value="' . $repnom->nom . '" '.$selected.'>' . $repnom->nom . '</option>';
    et pour rester cohérent (ordre des ' et ") :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                 if ($id1 == $repnom->nom){ $selected =  'selected="selected"'; }
    2/ Toujours pour être cohérent : pourquoi passer la "lettre" en GET, alors que le formulaire est en "post" ?
    Remplacer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <form id="formulaire" action="deces_indre.php?lettre=<?php echo $lettre ?>" method="post">
    Par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    <form id="formulaire" action="deces_indre.php" method="post">
    <input type="hidden" name="lettre" value="<?php echo  $lettre; ?>/>
    La récupération se fera alors avec $_POST['lettre'];.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Juillet 2014
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Cher (Centre)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2014
    Messages : 16
    Points : 10
    Points
    10
    Par défaut
    Merci beaucoup jreaux62, je me doutais bien que la solution serait simple mais je ne suis qu'un petit amateur.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 9
    Dernier message: 13/08/2008, 12h10
  2. Sélectionnez une valeur dans une liste déroulante
    Par azur_34 dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 09/05/2007, 09h32
  3. Réponses: 29
    Dernier message: 15/05/2006, 15h15
  4. Réponses: 4
    Dernier message: 20/04/2006, 00h34
  5. VBA : ajouter une valeur dans une liste déroulante
    Par remi59 dans le forum Access
    Réponses: 4
    Dernier message: 22/12/2005, 10h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo