SPIP-Contrib

SPIP-Contrib

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

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

Accueil du site > Navigation > Nuage de mots (tagcloud) > Nuage de mots-clés > Balise #FOREACH

Balise #FOREACH

3 février 2008 – par James – <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

2 votes

Ceci est une archive périmée mais qui reste intéressante, parfois autant pour l’article que les commentaires associés.

une balise pour appliquer un modèle à tous les éléments d’une balise contenant un tableau

SPIP s’est vu enrichi ces derniers mois de balises permettant des constructions de squelettes avec un niveau programmatique qui dépasse le cadre de la consultation de bases de données. En particulier une balise qu’on pourrait comparer aux instructions de bouclage de php lui-même : #FOREACH.

Dans la lignée des balises #SET, #GET et #ARRAY, cette balise permet de « boucler » sur un contenu équivalent à un tableau calculé dans le squelette en appliquant pour chacun de ses éléments un modèle SPIP.

Le choix de développer ce concept sous forme de balise plutôt que de boucle tient au fait que les boucles sont destinées à traiter des données issues de bases de données. Les besoins de boucler sur des contenus calculés dans les squelettes doivent donc être traités par une balise et des squelettes.

Le plugin nuage s’appuie sur cette balise,et la technique d’intégration dans 1.9.2 est aussi comprise dans le plugin, d’où sa présence dans cette rubrique.

Premier exemple

Dans un squelette quelconque, l’utilisation de #FOREACH affichera toutes les variables de la balise #ENV de la manière suivante :

- cle=> valeur

soit :
-  lang => fr
-  date => 2008-01-28 21:15:00
-  date_redac => 2008-01-28 21:15:00
-  ... => ...

Autrement dit, pour chaque élément du tableau associatif php que représente la balise #ENV, #FOREACH appliquera le modèle foreach.html (cf . plus bas). Dans ce modèle, le nom de la variable sera stocké dans #ENV{cle}, la valeur dans #ENV{valeur}.

Corsons l’affaire

On peut vouloir afficher le contenu d’une autre balise. #CONFIG par exemple. Pour cela, on passera le nom de la balise comme premier paramètre :

#FOREACH{CONFIG} affichera donc à peu près :
-  version_installee=> 1.927
-  charset=> utf-8
-  nom_site=> Mon site SPIP Stable
-  ... => ...

Et pour toute balise SPIP représentant un tableau php on aura un résultat similaire.

Changeons de forme

Le modèle foreach.html est celui qui est appliqué par défaut. Il est possible de le modifier, mais on peut aussi fabriquer un modèle dédié à une balise.

Le modèle foreach_balise.html correspond à #FOREACH{BALISE}.

On peut aussi souhaiter créer des modèles généraux et les utiliser pour telle ou telle balise. Par exemple, pour des listes non énumérées :

squelettes/modeles/foreach_ul_li.html :

sera le modèle qui correspond à [<ul>(#FOREACH{ENV,ul_li})</ul>]

.

Plus de valeurs

Enfin, dans les cas plus complexes, on peut passer plus de valeurs au modèles en respectant la structure de tableau suivante pour la balise que vous aurez conçue :

et en fournissant un modèle adapté :

La définition de la balise #NUAGE dans le plugin du même nom est un bon exemple de ce cas.

Le code

Cette balise se trouve dans la version de développement de SPIP, mais voici comment l’intégrer dans un site qui tourne encore avec une version 1.9.2.

Lorsque vous passerez à la prochaine version, ça se passera sans douleur grâce au petit test de version ci-dessous.

  1. Récuperer le fichier 193_fonctions.php du plugin nuage et copiez-le dans votre dossier squelettes/,
  2. dans squelettes/mes_fonctions.php :
    <?php

    //intégration des fonctions nécessaires de SPIP 1.9.3
    if($GLOBALS['spip_version'] < 1.93)
            include_spip('193_fonctions');

    //vos filtres...

    ?>
  1. dans squelettes/modeles/foreach.html :
    #PUCE #ENV{cle} => #ENV{valeur}<br />

Voir en ligne : #FOREACH

Retour en haut de la page

Vos commentaires

  • Le 16 juillet 2008 à 11:25, par Gilles VINCENT En réponse à : Balise #FOREACH

    Salut,

    Merci pour ce bon tutoriel.

    Vu que cette balise est désormais intégrée dans le Core, est-ce qu’il n’est pas raisonnable que cet article (où un clone) soit sur spip.net ?

    • Le 23 décembre 2009 à 00:17, par ? En réponse à : Balise #FOREACH

      c’est en train de se faire.

      (quoi « avec retard » ?)

  • Le 16 mai 2008 à 12:58, par ? En réponse à : Balise #FOREACH

    Bonjour,

    J’ai un petit soucis.
    Je ne vois pas la balise dans un SPIP 1.9.2d.

    Elle n’existerait pas que à partir de la version 1.9.3 ?

    merci

    • Le 16 mai 2008 à 16:02, par ? En réponse à : Balise #FOREACH

      lire dans l’article même :


      Cette balise se trouve dans la version de développement de SPIP, mais voici comment l’intégrer dans un site qui tourne encore avec une version 1.9.2.

Répondre à cet article

Retour en haut de la page

Ça discute par ici

  • Plugin Vidéo(s)

    23 novembre 2010 – 293 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Interface de gestion et modèle d’insertion des vidéos : Dailymotion Vimeo Youtube Modèle de la balise HTML5 video avec alternative flash html5media : Lecture HTML5/Flash pour tout navigateur des fichiers MP4/H264/Ogg/WebM/Mkv Support mobile, (...)

  • Plugin SPIPAL

    10 janvier 2011 – 79 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Pour intégrer un système de paiement immédiat via PayPal à certains de vos articles . Ce plugin est une mise à niveau pour la version SPIP 2.1.8 du Plugin GoPayPal qui était resté en SPIP 1.9.2 depuis 3 ans. Il change de nom pour ne pas faire trop de (...)

  • Le menu déroulant Babbibel

    2 juin 2009 – 303 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Un menu déroulant horizontal en jQuery sans limitation de profondeur et configurable avec CFG.

  • Traductions d’articles autrement 3

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

    Adaptation pour SPIP 3 du plugin Traductions d’articles autrement Ce plugin modifie légèrement l’interface de SPIP afin de rendre la traduction des articles plus aisée. Principe Des liens de langues, affichés en haut de l’article, permettent de (...)

  • Brownygreen

    3 février – <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Un thème simple de couleur marron et vert, en largeur fixe, constitué de 2 colonnes avec une en-tête facilement personnalisable. Présentation Adaptation de Versatility par E-cosystems. Si vous utilisez le plugin Menus, une navigation principale (...)