SPIP - Contrib

SPIP - Contrib

[ar] [en] [es] [fr] [it]

271 visiteurs en ce moment

fontsizeup fontsizedown
Accueil du site > Contribs > Navigation > Menus déroulants > Liste déroulante avec sélection du bon élément
[2 commentaires]

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

mercredi 21 septembre 2005, par RealET

  • Digg
  • Del.icio.us
  • Facebook
  • Google
  • Technorati
1 vote

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 :

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

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
  • ...

P.-S.

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é).

Retour en haut de la page

2 Messages de forum

Voir toute la discussion

  • Répondre à ce message

    22 septembre 2005 15:38 , par 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

  • Répondre à ce message

    22 septembre 2005 14:07 , par 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...

Répondre à cet article

Retour en haut de la page

Ça discute par ici