SPIP - Contrib

[ar] [en] [es] [fr] [it]



Accueil du site > Navigation > Tris Alphabétiques > Archives Tris Alphabétiques

VarianteContribCreer-un-index-classement

jeudi 22 février 2007. Dernier ajout samedi 28 juillet 2007



Variante n°1 | Variante n°2

Variante n°1 de "Créer un index : classement alphabétique de mots-clés (articles, etc.)" à partir de Spip 1.8

Avec le filtre |unique de Spip 1.8, on pourrait théoriquement créer un index avec une seule boucle :

Le filtre |substr{0,1} correspond à une fonction php qui retourne 1 caractère à partir du caractère 0 de la chaîne #TITRE, soit la première lettre du titre. Le filtre |unique fait que cette lettre ne s’affiche qu’une fois, elle n’est donc pas répétée pour les autres mots commençant par la même lettre.

[Erreur...7]Dans mes_fonctions.php3

Dans mon squelette :

Et pour faire plus joli, on ajoute le menu alphabétique et les ancres nommées...

[Erreur...15]Il faut sans doute investiguer un peu plus loin le remplacement des caractères accentués, mais je n’y connais rien... Ça marche en tout cas sur mon site qui utilise le jeu de caractères iso-8859-1 (voir Configuration > Gestion des langues), mais je ne sais pas ce que ça donnerait dans un site en uft-8 par exemple.

[Erreur...17]Ok, bon. Alors voici une autre solution, mais en php... Aurélie (21/02/2007)


Variante n°2 de "Créer un index : classement alphabétique de mots-clés (articles, etc.)" avec du php

Cette variante a été testée avec un Spip 1.9.1 qui utilise le codage de caractères UTF-8.

Le php permet de contourner un problème assez insoluble : j’ai beau m’escrimer à nettoyer les premières lettres de chaque mot du glossaire pour que les a, à, ä, á aillent ensemble, reste que le tri des mots se fait dans la boucle elle-même. Or Spip (ou MySQL?) ne le fais pas (encore?) tout à fait bien (cf. explication de Claude ci-dessus).

D’abord le nettoyage :

[Erreur...25][Erreur...26]Puis la question du tri :

Dans le squelette où doit apparaître le glossaire :

Explications (je n’explique pas l’html) :

[Erreur...32]Pour chaque mot retourné par la boucle, on va créer une ligne du tableau :

$glossaire[$lettre1][$mot] = "<dt><a href=\"#index\">[(#TITRE|supprimer_numero|texte_script)]:</a></dt><dd>[(#DESCRIPTIF|sinon{#TEXTE}|texte_script)]&nbsp;</dd>";

[Erreur...35]Chaque enregistrement donne donc quelque chose comme ça : $glossaire[T][Titre] = "<dt><a href=\"#index\">Titre:</a></dt><dd>Descriptif&nbsp;</dd>";

[Erreur...37]Au sortir de la boucle, on trie notre tableau $glossaire : "ksort() trie le tableau suivant les clés [chez nous : A, B, C...], en maintenant la correspondance entre les clés et les valeurs".

[Erreur...39][Erreur...40]N’hésitez pas à raconter vos tests et améliorations ci-dessous.


J’ai mis une contrib qui fait un index alphabétique avec #ARRAY Tri alphabétique tout en SPIP 2 boucles simples et des fonctions reprises d"’ici même

ça marche bien en spip 1.9.2+
echo


Répondre à cet article



Suivre la vie du site RSS 2.0 | Plan du site | Espace privé | Charte et vie SPIP-Contrib | SPIP | L'autre.net