SPIP

[ar] [ast] [bg] [br] [ca] [co] [cpf] [cs] [da] [de] [en] [eo] [es] [eu] [fa] [fon] [fr] [gl] [id] [it] [ja] [lb] [nl] [oc] [pl] [pt] [ro] [ru] [sk] [sv] [tr] [uk] [vi] [zh] Espace de traduction

Download

{doublons}

30 maart

Alle versies van dit artikel:

De voorwaarde {doublons} voorkomt het voor een tweede keer weergeven (in een andere lus) van dezelfde resultaten.


Wanneer je de voorwaarde {doublons} eenmaal hebt ontdekt, zal je hem vaak in je skeletten gebruiken. De voorwaarde opent interessante mogelijkheden, vooral door enkele latere toevoegingen:
-  je kunt {doublons} benoemen en er dus meerdere in hetzelfde skelet gebruiken,
-  en je kunt ook anti-{doublons} uitvoeren!

Basistoepassing: een element slechts eenmaal op een pagina tonen

In het standaardskelet sommaire.html vind je een voorbeeld:

  1. <BOUCLE_recente_artikelen(ARTICLES) {par date}{inverse} {0,2} {doublons}>
  2. weer te geven elementen, bijvoorbeeld  #TITRE
  3. </BOUCLE_recente_artikelen>
  4. <BOUCLE_overige_artikelen(ARTICLES) {par date}{inverse} {doublons} >
  5. weer te geven elementen, bijvoorbeeld #TITRE
  6. </BOUCLE_overige_artikelen>

We laten dus de twee nieuwste artikelen in omgekeerde datumvolgorde zien EN zorgen ervoor dat ze niet tweemaal worden weergegeven. Zoals je ziet, zijn de lussen "_recente_artikelen" en "_overige_artikelen" op identieke wijze opgebouwd en zouden (zonder de toevoeging {doublons}) dus ook dezelfde lijst van artikelen weergeven.

Dankzij de werking van {doublons} zullen de twee artikelen waartoe de eerste lus beperkt is ({0,2}), niet nogmaals worden weergegeven in de lus "_overige_artikelen" (die dezelfde {doublons} bevat).

Andere toepassing: elementen uitsluiten

Uitsluiten volgens een trefwoord

Vaak rapporteren gebruikers op spip-users een probleem van het type:

"Het lukt mij niet om elementen uit te sluiten op basis van hun trefwoord. Ik probeerde:

maar dit werkt niet!"

Wat deze gebruiker wil, is alle rubrieken weergeven die niet het trefwoord "verborgen" hebben. Maar wat ze met de code {titre_mot != verborgen} aangeven, betekent: selecteer alle rubrieken MET een trefwoord EN dit trefwoord mag niet "invisible" zijn.

De oplossing: maak een lege lus die selecteert op dit trefwoord en een tweede lus die alle rubrieken selecteert, maar die van de eerste lus uitsluit met voorwaarde {doublons}.

Het bovenstaande probleem wordt dus opgelost met een eerste lus:

Deze lus selecteert alle rubrieken met het trefwoord "verborgen" , maar geeft niets weer.

  1. <BOUCLE_rubrieken(RUBRIQUES) {racine}{par num titre, titre} {doublons}>
  2. {hier de weergave}
  3. </BOUCLE_rubrieken>

Dankzij de voorwaarde {doublons} selecteert deze tweede lus alle andere rubrieken en voert vervolgens de gewenste handelingen uit.

Een {doublons} benoemen

Objectief: op een beginpagina willen we artikelen en beschouwingen van elkaar scheiden. Van beide willen we onder een aparte kop de nieuwste twee laten zien en vervolgens alle andere. Een beschouwing wordt gekenmerkt door een trefwoord met {id_mot=1}:

  1. <BOUCLE_recente_beschouwingen(ARTICLES) {!par date}{id_mot=1} {0,2} {doublons bes}>
  2. weer te geven elementen, bijvoorbeeld  #TITRE
  3. </BOUCLE_recente_beschouwingen>
  4. <BOUCLE_overige_beschouwingen(ARTICLES) {!par date}{id_mot=1} {doublons bes} >
  5. weer te geven elementen, bijvoorbeeld  #TITRE
  6. </BOUCLE_overige_beschouwingen>
  7.  
  8. <BOUCLE_recente_artikelen(ARTICLES) {!par date} {0,2} {doublons art}>
  9. weer te geven elementen, bijvoorbeeld  #TITRE
  10. </BOUCLE_recente_artikelen>
  11. <BOUCLE_overige_artikelen(ARTICLES) {!par date} {doublons art} >
  12. weer te geven elementen, bijvoorbeeld  #TITRE
  13. </BOUCLE_overige_artikelen>

En niets houd je tegen om een {doublons} te benoemen met behulp van een baken van SPIP, zoals: {doublons #TITRE} of {doublons #_mijnlus:TITRE} of zelfs {doublons (#_mijnlus:TITRE|supprimer_numero)}.

Geavanceerde toepassing: anti-doublons

Mechanisme van anti-doublons

Hier gaat {doublons} het mogelijk maken de resultaten uit meerdere lussen met verschillende criteria te verzamelen en vervolgens met {!doublons} de gewenste verwerkingen doen met de verzamelde gegevens.

Dit zijn de te volgen stappen:

We selecteren een eerste reeks artikelen (maar geven niets weer)...

<BOUCLE0(ARTICLES){id_mot=2}{doublons A}></BOUCLE0>

We selecteren een tweede reeks artikelen (maar geven niets weer)...

<BOUCLE1(ARTICLES){id_auteur=1}{doublons A}></BOUCLE1>

En we geven beide weer dankzij de anti-doublons:

<BOUCLE2(ARTICLES){par date}{!doublons A}>#TITRE<br></BOUCLE2>

Een anti-doublons voorbeeld

Objectief: een lus maken die de artikelen uit alle rubrieken selecteert, behalve van rubrieken 2 en 3, EN van rubriek 4 alleen artikelen die jonger zijn dan 60 dagen.

De oplossing: we beginnen met een lus die de artikelen selecteert uit alle rubrieken, behalve de rubrieken 2 en 3, maar ook 4...

<BOUCLE0(ARTICLES) {id_rubrique !IN 2,3,4}{doublons tri1}></BOUCLE0>

....vervolgens doen we een tweede lus op rubriek 4...

<BOUCLE1(ARTICLES) {id_rubrique=4}{age<60}{doublons tri1}></BOUCLE1>

...en in een laatste lus wat we gaan weergeven dankzij de anti-doublons...

<BOUCLE2(ARTICLES){par date}{!doublons tri1}>#TITRE<br></BOUCLE2>

N.B.

Originele artikel: SPIP-Contrib.net.
Gepubliceerd op spip.net door Teddy


Het skelet van deze bladzijde zien Site gebouwd met SPIP | Vertaalruimte | Privé-site