Liste déroulante avec sélection du bon élément

Afficher dans un site SPIP une liste déroulante dont l’élément sélectionné soit celui que l’on vient de demander avant le ré-affichage de la page.

Un peu de théorie

Une liste déroulante, c’est :

<label for="idselect">L'étiquette de la zone de liste déroulante</label>
  <select name="param" id="idselect">
    <option value="">Faites votre choix</option>
    <option value="1">Valeur 1</option>
    <option value="2" selected="selected">Valeur 2</option>
    <option value="3">Valeur 3</option>
    <option value="4">Valeur 4</option>
  </select>

Qui donne ceci :


avec la valeur 2 qui est présélectionnée.

Logiquement, quand on envoie un formulaire et que la page de résultat ré-affiche ce formulaire, on s’attend à ce que la liste déroulante soit positionnée sur la valeur que l’on a choisie.

Syntaxe SPIP

<label for="idselect">L'étiquette de la zone de liste déroulante</label>
  <select name="param" id="idselect">
    <option value="">Faites votre choix</option>
    <option value="1"[(#ENV{param}|=={1}|?{' selected="selected"',''})]>Valeur 1</option>
    <option value="2"[(#ENV{param}|=={2}|?{' selected="selected"',''})]>Valeur 2</option>
    <option value="3"[(#ENV{param}|=={3}|?{' selected="selected"',''})]>Valeur 3</option>
    <option value="4"[(#ENV{param}|=={4}|?{' selected="selected"',''})]>Valeur 4</option>
  </select>

Signification de ce code

[(#ENV{param}|=={1}|?{' selected="selected"',''})] signifie :

  • prendre la valeur du paramètre d’URL nommé “param” (càd, le name du select) : [(#ENV{param})]
  • Voir s’il est égal à une valeur : |=={1}
  • S’il est effectivement égal à la valeur, renvoyer : selected="selected", sinon, ne rien renvoyer : ''

Exemples d’usage

  • une recherche permettant de limiter les rubriques du site par liste déroulante
  • une pagination par liste déroulante
  • un calendrier avec choix de la période par liste déroulante
  • ...

Notez que la syntaxe HTML donnée ici est en fait du XHTML (sachant qu’il est sans doute plus didactique de donner un exemple dans la syntaxe la plus récente des normes du W3C).

En particulier, cela a pour conséquence que les attributs doivent avoir une valeur selected="selected".

Le label quant à lui permet de le cliquer pour activer la liste déroulante (facteur d’accessibilité).

Discussion

4 discussions

  • meyodin

    Merci pour la signification de votre code, je planchais sur une boucle depuis 7 jours et j’ai enfin trouvé la solution grâce à ça !!!

    Reply to this message

  • Bonjour j’essaye ce syntaxe mais ca ne marche pas :

    <label for="idselect">Service : </label>
    		<br />
      <select name="param" id="idselect">
        <option value="">Faites votre choix</option>
    	<BOUCLE_reponses(service){idser}>
        <option value="#IDSER"[(#ENV{param}|=={#IDSER}|?{' selected="selected"',''})]>#NOMSER</option>
      </BOUCLE_reponses>
      </select>
    	<br />

    Reply to this message

  • 1

    Abandonne Spip...

    Reply to this message

  • 1
    Jean-luc Grellier

    J’ai bien essayé ça :

    <BOUCLE_art2(ARTICLES){id_secteur=13}{par date}{inverse}>
    [<option value="[(#DATE|annee)]-[(#DATE|mois)][(#ENV{date}|=={[(#DATE|annee)]-[(#DATE|mois)]}|?{' selected="selected"',''})]">(#DATE|nom_mois|unique)[ - (#DATE|annee)]</option>]
    </BOUCLE_art2>

    Mais ça ne fonctionne pas... pas de message d’erreur non plus...

    • Jean-luc Grellier

      Merci Jacques, il faut éviter de faire ce que j’ai fait : un champ sélect qui s’appelle date (c’est une variable réservée à spip)... par contre mon problème est ailleurs et est du à la complexité de ma page... si cela intéresse quelqu’un :

      <form name="formulaire">
       <label for="iddate">Période:</label>
        <select name="ladate" id="iddate">
      <BOUCLE_art2(ARTICLES){id_secteur=13}{par date}{inverse}>
      [<option value="[(#DATE|annee)]-[(#DATE|mois)][(#ENV{ladate}|=={[(#DATE|annee)]-[(#DATE|mois)]}|?{' selected="selected"',''})]">(#DATE|nom_mois|unique)[ - (#DATE|annee)]</option>]
      </BOUCLE_art2>
        </select><INPUT TYPE="submit"  VALUE="Rechercher">
      </form>
                                                      
      <div class="archives">
      <h4>Actualités de [(#DATE|nom_mois)] [(#DATE|annee)]</h4>                <ul>
       <BOUCLE_princ(ARTICLES){mois_relatif=0}{id_secteur=13}{par date}{inverse}>
        <li>[<a id="lien" href="#URL_ARTICLE">(#TITRE|supprimer_numero)</a> - ]<BOUCLE_RUBART(RUBRIQUES){id_rubrique}>[[<a href="#URL_RUBRIQUE">(#TITRE|supprimer_numero)</a>]]</BOUCLE_RUBART>[ - (#DATE|jour)]/[(#DATE|mois)]</li>
       </BOUCLE_princ>
      </ul>
      </div>

      Cela ne peut fonctionner puisque je prends le critère d’âge relatif (celui qui est passé en variable ou la variable date si rien n’est passé)... c’est pour cela qu’il faut que j’utilise date dans mon formulaire, cela me permet d’affecter une valeur à cette variable...

      Si cela intéresse quelqu’un...

      Merci

    Reply to this message

Add a comment

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite / PostgreSQL
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparait.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

Who are you?
[Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom