Técnicas para extender las posibilidades de los bucles

Aquí se dan varias técnicas para ampliar las posibilidades ofrecidas por los bucles de SPIP estándar:

En primer lugar una técnica para poner a prueba en el criterio IN de un bucle con SPIP 1.9.2 o 2.0.x, y también ofrecer la posibilidad de escribir bucles que parecían imposibles de hacer. Luego, una segunda técnica disponible para SPIP 2.0.x, para hacer nuevos bucles de juntura “automática” o “forzada”. Pídeles la luna a tus bucles:)!

La idea

Digamos que a menudo utilizas la misma lista de valores en el criterio IN de un bucle. Por ejemplo, el siguiente:

<BOUCLE_art(ARTICLES){id_article IN 12,13,14,25}>
	<h1>#TITRE</h1>
</BOUCLE_art>

El bucle precedente lista los artículos con ID 12, 13, 14 o 25.

Una solución para compartir tu lista en un mismo esqueleto

Una opción para comparti rsta lista es cargarla en un arreglo estático (mira este artículo. Podemos usarlo varias veces sobre el mismo esqueleto (lo que facilita el mantenimiento). Por ejemplo:

[(#SET{miarreglo,#ARRAY{0,12,1,13,2,14,3,25}})]
 
<BOUCLE_art1(ARTICLES){id_article IN #GET{miarreglo}|sinon{0}}{par hasard}>
	<h1>#TITRE</h1>
</BOUCLE_art1>
 
<BOUCLE_art2(ARTICLES){id_article IN #GET{miarreglo}|sinon{0}}{par titre}>
	<h1>#TITRE</h1>
</BOUCLE_art2>

Una solución para todos los esqueletos

Ahora imaginemos que usas esa lista en varios esqueletos. Aquí hay una manera de compartirla:

Puedes crear un simple esqueleto que sólo contiene una cadena formada con la lista de valores separados por un caracter raramente usado (la barra vertical ’|’ es una buena idea).

Por ejemplo, yo creé el esqueleto milista.html con este contenido:

  1. 12 | 13 | 14 | 25

y el esqueleto miprueba.html

#CACHE{0}
<BOUCLE_art(ARTICLES){id_article IN #INCLURE{fond=milista}|explode{'|'}}>
	<h1>#TITRE</h1>
</BOUCLE_art>

El filtro "explode es una función php que separa la cadena pasada como parámetro y llena una matriz con valores. La función toma como primer parámetro el carácter utilizado para la separación ... y ¡voilá! Es como si el esqueleto incluído pasara una matriz como parámetro.

Cómo lograr bucles “imposibles”

Aquí hay un ejemplo para hacer un bucle normalmente imposible con SPIP 1.9.2: obtener la lista de artículos en la secciones marcadas con la palabra clave con ID 15.

Una de las posibilidades de los arreglos dinámicos sería hacer el siguiente esqueleto (mira también el plugin SPIP Bonux para construir arreglos dinámicos):

#CACHE{0}
 
#SET{miarreglo, #ARRAY{}}
<BOUCLE_rub(RUBRIQUES){id_mot=15}>
 [(#SET{miarreglo,
   #GET{miarreglo}|push{#ID_RUBRIQUE}
 })]
</BOUCLE_rub>
 
<BOUCLE_art(ARTICLES){id_rubrique IN #GET{miarreglo}|sinon{0}}{par titre}>
<h1>#TITRE</h1>
</BOUCLE_art>

Esta solución funciona perfectamente, pero requiere reescribir parte del código en cada esqueleto donde se usa.

Aquí está la solución donde compartimos la primer parte:
Creamos un archivo list-rubriques.html que genera la lista de identificadores separados por barras verticales

  1. <BOUCLE_rub(RUBRIQUES){id_mot?}{id_groupe?}{'|'}>#ID_RUBRIQUE</BOUCLE_rub>

Puedes usar este “sub-bucle” en todos los otros esqueletos. Por ejemplo, puede usar para el siguiente bucle en otro esqueleto:

<BOUCLE_art(ARTICLES){id_rubrique IN #INCLURE{fond=list-rubriques}{id_mot=15}|explode{'|'}|sinon{0}}{par titre}>
<h1>#TITRE</h1>
</BOUCLE_art>

Compatibilidad :
Probado con SPIP 2.0.9, pero también debería funcionar con SPIP 1.9.2.

Una técnica (mucho) más eficiente con SPIP 2.0.x

Con la versión 2.0 llegaron las composiciónes automáticas (ver este artículo en el sitio programmer.spip.org). Podemos usar el siguiente bucle para obtener el mismo resultado:

<BOUCLE_art(ARTICLES mots_rubriques){id_mot=15}{par titre}>
<h1>#TITRE</h1>
</BOUCLE_art>

Las ventajas:
-  No hay inclusiones
-  Todo el trabajo de composición lo realiza la base de datos, lo que implica mayor eficiencia.

Para mayor evidencia, aquí está la consulta provista por el modo debug (?var_mode=debug):

SELECT articles.titre, articles.lang
FROM `mabase`.spip_articles
AS `articles`
INNER JOIN `mabase`.spip_mots_rubriques
AS L1 ON ( L1.id_rubrique = articles.id_rubrique )
WHERE (articles.statut = 'publie')
AND (articles.date < '9999-12-31')
AND (L1.id_mot = 15)
GROUP BY articles.id_article
ORDER BY articles.titre

Para utilizar las nuevas posibilidades ofrecidas por SPIP 2.0.x, no dudes en valerte una herramienta como PhpMyAdmin que están ofrecidas, en general, por todos los alojamientos, para descubrir las tablas y su estructura (¡que es muy clara!). Así podrás encontrar las tablas que intermedian la composición.

A continuación, comprueba qué tipo de composición genera SPIP examinando tu esqueleto con en modo debug y mostrando el “cálculo” generado por el bucle en cuestión. Para esto, quizás quieras aprender algunos conceptos básicos de SQL

updated on 25 August 2009

Discussion

Une discussion

  • Definitivamente de SPIP solo conozco un 1% jejeje sigue el estudio...
    Cada día confirmo que la elección de SPIP es la correcta...

    Reply to this message

Comment on this article

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