SPIP-Contrib

SPIP-Contrib

عربي | Deutsch | English | Español | français | italiano

273 Plugins, 191 contribs sur SPIP-Zone, 57 visiteurs en ce moment

Accueil du site > Navigation > Menus réactifs > Liste déroulante avec sélection du bon élément

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

21 septembre 2005 – par RealET – <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

7 votes

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

Vos commentaires

  • Le 5 juillet 2011 à 10:51, par meyodin En réponse à : Liste déroulante avec sélection du bon élément

    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 !!!

    Répondre à ce message

  • Le 21 juin 2011 à 11:25, par yasean En réponse à : Liste déroulante avec sélection du bon élément

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

    1. <label for="idselect">Service : </label>
    2.                 <br />
    3.   <select name="param" id="idselect">
    4.     <option value="">Faites votre choix</option>
    5.         <BOUCLE_reponses(service){idser}>
    6.     <option value="#IDSER"[(#ENV{param}|=={#IDSER}|?{' selected="selected"',''})]>#NOMSER</option>
    7.   </BOUCLE_reponses>
    8.   </select>
    9.         <br />

    Répondre à ce message

  • Le 24 mars 2010 à 09:04, par Seb En réponse à : Liste déroulante avec sélection du bon élément

    Abandonne Spip...

    Répondre à ce message

  • Le 22 septembre 2005 à 14:07, par Jean-luc Grellier En réponse à : > Liste déroulante avec sélection du bon élément

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

    • Le 22 septembre 2005 à 15:38, par Jean-luc Grellier En réponse à : > Liste déroulante avec sélection du bon élément

      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

Répondre à cet article

Qui êtes-vous ?

Pour afficher votre trombine avec votre message, enregistrez-la d'abord sur gravatar.com (gratuit et indolore) et n'oubliez pas d'indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici Les choses à faire avant de poser une question (Prolégomènes aux rapports de bugs. )
Ajouter un document

Retour en haut de la page

Ça discute par ici

  • Zpip-dist en HTML5

    15 juin 2010 – 10 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Une surcharge des squelettes Zpip-dist qui tire parti des nouvelles balises offertes par la spécification HTML5. Attention, ce plugin n’est plus compatible avec les nouvelles versions de Zpip, qui a connu plusieurs incompatibilités de nomenclature (...)

  • Une licence pour un article

    18 avril 2007 – 25 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Sur une idée originale de erational, voici un plugin permettant de lier une licence à un article.

  • Plugin Parrainage

    6 novembre 2011 – <blink style='color:red;'>public|spip|ecrire:commentaire</blink>

    Permettre aux utilisateurs d’inviter leurs contacts à s’inscrire sur le site. Description Vous connaissez le web moderne et son cortège d’applis toujours en version « beta » et de buzz sur le dernier réseau à la mode ? Vous voulez vous aussi vous y (...)

  • Formulaire de contact libre

    27 avril 2011 – 36 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Dans SPIP il n’y a pas un formulaire de contact, mais autant de formulaires de contact que d’auteurs. Cette phrase de Romy, dans son article Une page de contact dans mon SPIP, pointe un petit manque de SPIP. La possibilité d’insérer rapidement un (...)

  • Plugin Mot de Passe Compliqué

    2 novembre 2007 – 16 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Ce plugin ajoute un testeur de complexité de mot de passes dans les formulaires de choix de mot de passe de SPIP.