SPIP-Contrib

SPIP-Contrib

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

290 Plugins, 198 contribs sur SPIP-Zone, 81 visiteurs en ce moment

Accueil > Squelettes > Tutoriels pour squelettes > Passer TOUS les paramètres de l’URL à un INCLURE

Passer TOUS les paramètres de l’URL à un INCLURE

17 décembre 2006 – par mortimer, Olivier GENDRIN – commentaires

0 vote

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

Il est parfois utile de faire descendre des paramètres d’url d’un squelette vers un squelette inclus. On a ainsi pris l’habitude d’ajouter {id_article} et autres dans les balises INCLURE de SPIP.

Mais que faire quand on ne sait pas quel paramètre de l’url on veut passer exactement (parce que ces paramètres sont variables etc...)

Voici un filtre qui permet de transférer le contenu de la balise #ENV d’un squelette à un squelette inclus.

Mise en œuvre

Son utilisation est assez simple, il faut :

-  placer le code suivant dans votre fichier mes_fonctions.php [1] :

  1. function env($env,$par='') {
  2.   $env = str_replace('"','"',$env);
  3.   if($par) {
  4.         $env = unserialize($env);
  5.         return entites_html($env[$par]);
  6.   }
  7.   return $env;
  8. }

Télécharger

-  dans le squelette qui fait l’inclusion, ajouter {env=#ENV} à l’inclusion :
<INCLURE{fond=test}{env=#ENV}>

-  dans le squelette inclus, pour acceder à un paramètre d’url de nom mon_param :

  1. [(#ENV{env}|env{mon_param})]

Exemple

Si on utilise les mots-clés pour inclure certaines noisettes :

  1. <BOUCLE_coeur_article (MOTS) {id_article} {type = _squelettes_article}>
  2.     <INCLURE {fond=squelettes_articles/#TITRE} {id_article}>
  3. </BOUCLE_coeur_article>
  4.     <INCLURE {fond=squelettes_articles/defaut} {id_article}>
  5. <//B_coeur_article>

Télécharger

Ces noisettes ayant des comportements très différents, il est possible de rapidement se retrouver avec plusieurs paramètres différents à ajouter à chaque fois (un pour la pagination, un pour un critére de tri, un pour un filtre par date, …).

Pour être sûr de retrouver le paramètre dont on a besoin, on passe au squelette inclus l’ensemble de #ENV en écrivant <INCLURE {fond=squelettes_articles/#TITRE} {id_article} {env=#ENV}>.

Maintenant, si on a besoin d’un paramètre date dans le squelette inclus, on obtiendra sa valeur à l’aide de [(#ENV{env}|env{date})]

Notes

[1ou le fichier fonctions relatif au squelette inclus

Dernière modification de cette page le 3 mars 2015

Retour en haut de la page

Vos commentaires

  • Le 13 février 2012 à 19:57, par YannX En réponse à : Passer TOUS les paramètres de l’URL à un INCLURE

    Fonctionnalité intégrée au Core depuis...... (au moins SPIP v2 ! )

    Répondre à ce message

  • Le 18 janvier 2007 à 13:25, par piif En réponse à : Passer TOUS les paramètres de l’URL à un INCLURE

    Merci pour l’idée, c’est pile ce qu’il me fallait :-)

    Pour éviter l’usage systématique du filtre env, qui est un peu lourd, on peut définir la fonction suivante (dans mes_fonctions ou un plugin) :

    function balise_SETENV($p) {
            $p->code = "(\$Pile[0]= array_merge(unserialize(\$Pile[0]['env']), \$Pile[0]))&&''";
            return $p;
    }

    Cette fonction copie le contenu de l’argument env dans l’environnement courant.

    Donc si le squelette inclu contient au début un #SETENV, [(#ENV{env}|env{mon_param})] peut être remplacé par #ENV{mon_param} ou même #MON_PARAM s’il n’y a pas de risque de confusion avec une balise de boucle.

    Attention, pour éviter les strreplace et compagnie, il faut appeler cette version avec{env=#ENV**}

    • Le 18 janvier 2007 à 17:17, par Fil En réponse à : Passer TOUS les paramètres de l’URL à un INCLURE

      Le hack est pas mal, mais (pour mémoire) quelqu’un avait eu l’idée de faire un critère d’inclusion spécifique qui fasse ça « proprement ». Seulement j’ai oublié quel nom on voulait lui donner...

    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

  • Convertir un site SPIP 3 en utf-8 avec le plugin Grenier

    8 janvier 2014 – 24 commentaires

    SPIP 3 fonctionne nativement avec l’encodage universel unicode utf-8. Sur certains sites (par exemple sur une mise à jour), on peut avoir un site qui est resté en iso-latin ce qui n’est pas conseillé (source de bugs, d’incompatibilité, ...) . (...)

  • Hébergeurs payants

    24 janvier 2009 – 34 commentaires

    Cet article en encore à réorganiser / scinder en deux selon le type (mutualisé ou pro). À priori, SPIP fonctionnera sur tout hébergeur payant traditionnel (qui propose PHP et MySQL). Merci de ne pas mettre des remarques du genre « l’hébergeur truc (...)

  • MediaBox

    10 mai 2010 – 539 commentaires

    Avertissement Le présent plugin est installé et activé par défaut sur toute les version de SPIP > 3.0. Inutile donc de l’installer manuellement sauf si vous utilisez SPIP 2.1. Aperçu La MediaBox est une Boîte multimédia polyvalente et (...)

  • DocumentationFormsTables

    9 décembre 2006 – commentaires

    Article publié : ces notes et d’autres sont désormais publiées sur SPIP-Contrib ici Forms & tables - carnet de notes, donc il faut mieux y aller pour tout complément Différence entre un formulaire et une table un formulaire est dédié a la saisie (...)

  • GIS 4

    11 août 2012 – 1495 commentaires

    Présentation et nouveautés La version 4 de GIS abandonne la libraire Mapstraction au profit de Leaflet. Cette librairie permet de s’affranchir des librairies propriétaires tout en gardant les mêmes fonctionnalités, elle propose même de nouvelles (...)