Principe
Si, dans le squelette rubrique.html, on a mis une BOUCLE(ARTICLES)
avec le paramêtre {tout}
, les pages rubriques vont grandir au fur et à mesure du remplissage du site. Si on a limité le nombre d’articles (avec le paramètre {0, 20}
, par exemple), on « perd » les plus anciens.
L’avantage de cette boucle, est qu’on n’est plus obligé de limiter le nombre de liens vers les articles dans une page rubrique, tout en évitant de voir grandir cette page à l’infini. C’est ce qu’on appelle la pagination.
Exemple
Ici avec une syndication, mais c’est le même principe qu’avec les articles : http://wb.attac.be/rubrique.php3?id_rubrique=48
Télécharger le code
Pagination : version III, sept 2003 à télécharger ici
Adresse de publication originale :
http://support.cassiopea.org/spip/spip-tech.shtml#nb_article_rub
Pour ceux qui veulent en savoir plus :
Codes de la contribution
- le code + la boucle à copier / coller dans la page rubrique.
- le fichier article-pagine.inc à télécharger dans le répertoire racine de votre site spip (là où il y a les squelettes .php3).
N’oubliez pas de télécharger aussi fleche-gauche.gif et fleche-droite.gif dans /NAVPICS.
A propos des squelette inclus :
Si vous mettez la boucle dans un squelette inclus, il est nécessaire mais apparament pas suffisant d’appeler le squelette inclus avec
<BOUCLE_rubrique(RUBRIQUES){id_rubrique}>
Le code et la boucle ci-dessous ...
</BOUCLE_rubrique>
1) le code + la boucle à copier / coller dans la page rubrique
<!-- Compte et affiche le nombre total d'articles de la rubrique -->
<B_compte_articles>
<BOUCLE_compte_articles(ARTICLES){id_rubrique}>
<?php $total=#TOTAL_BOUCLE; ?>
</BOUCLE_compte_articles>
Nombre total d'articles: #TOTAL_BOUCLE
</B_compte_articles>
<!-- Initialisation du compteur et du nombre d'articles par page (php) -->
<?php
//Nombre d'articles par page: Ici, 15 article par page. Vous pouvez bien sur mettre un autre nombre que 15..
//Attention, il doit être égal au nombre du critère {debut_article,15}
$nb_art_par_page=15;
if (isset($debut_article)) {$compteur=$debut_article;} else {$compteur=0;}
?>
<B_articles>
<b>Articles</b><br><br>
<ul>
<!-- Attention: Le nombre 15 dans {debut_article,15} doit être égal à $nb_art_par_page=15; ci-dessus -->
<BOUCLE_articles(ARTICLES){id_rubrique}{par date}{inverse}{debut_article,15}>
<li><a href="#URL_ARTICLE">[(#TITRE)]</a></li>
<!-- Incrémentation du compteur (php) -->
<?php if ($compteur<0) {$compteur=0;} else {$compteur+=1;} ?>
</BOUCLE_articles>
</ul>
<!-- Lien vers page précédente et suivante (php) -->
<div style="text-align:left">
<?php
// Param: $idtype = #ID_RUBRIQUE|#ID_MOT|... , $type = "rubrique"|"mot"|...
$idtype=#ID_RUBRIQUE; $type = "rubrique";
include "article-pagine.inc";
?>
</div>
</B_articles>
<br>Il n'y a pas d'articles dans cette rubrique.
<//B_articles>
2)le code contenu dans "article-pagine.inc
<?php
// Auteur: robert.sebille(at)cassiopea.org - sept 2003
// Sous licence GNU/GPL http://www.gnu.org/copyleft/gpl.html
// Retourne les liens XX articles suivants / précédents
// Gestion des n° de pages
$mod0 = $total % $nb_art_par_page;
if ($mod0 == 0)
{$total_page = floor($total / $nb_art_par_page);}
else
{$total_page = floor($total / $nb_art_par_page) + 1;}
$page = floor($compteur / $nb_art_par_page);
$page_inv = $total_page - $page + 1;
if ($mod0 !=0 && ($total - $compteur) < $mod0)
{$page = $total_page; $page_inv = 1; $offset_art_prec = $total - $mod0 - $nb_art_par_page;}
else
{$offset_art_prec = $compteur - (2 * $nb_art_par_page);}
// Gestion de l'affichage des liens
// fleche gauche
if ($total_page > 1) {
$affiche = ""; $pageplus_inv = $page_inv + 1; $pagemoins_inv = $page_inv - 1;
if ($offset_art_prec >= 0)
{$affiche .= "<a href='$type.php3?id_$type=$idtype&debut_article=$offset_art_prec' title='Les ".$nb_art_par_page." articles suivants'><img src='NAVPICS/fleche-gauche.gif' width='15' height='9' alt='Vers la page ".$pageplus_inv." et les ".$nb_art_par_page." articles suivants' border='0'></a> ";}
// Milieu
$affiche .= "Page(s):";
$MaxPageLinks = 10;
if ($total_page - ($MaxPageLinks - 1) > $page_inv)
{$PageStart = $page_inv + ($MaxPageLinks - 1);} else {$PageStart = $total_page;}
if ($PageStart - ($MaxPageLinks -1) < 1)
{$PageEnd = 1;} else {$PageEnd = $PageStart - ($MaxPageLinks - 1);}
for ($i = $PageStart; $i >= $PageEnd; $i--) {
$offset_inv = ($nb_art_par_page * $total_page) - ($i * $nb_art_par_page);
if ($i != $page_inv)
{$affiche .= " <a href='$type.php3?id_$type=$idtype&debut_article=$offset_inv'> $i </a>";}
else
{$affiche .= " | $i |";}
} // End ($i = $PageStart; $i >= $PageEnd; $i--)
// fleche droite
if ($compteur < $total)
{if (($compteur+$nb_art_par_page) > $total) {$nb_art_suiv = $total - $compteur;} else {$nb_art_suiv = $nb_art_par_page;}
$affiche .= " <a href='$type.php3?id_$type=$idtype&debut_article=$compteur' title='Les ".$nb_art_suiv." articles précédents'><img src='NAVPICS/fleche-droite.gif' width='15' height='9' alt='Vers la page ".$pagemoins_inv." et les ".$nb_art_suiv." articles précédents' border='0'></a>";}
// Dessous
$affiche .= "<br>Nombre total de page(s): $total_page";
} // End if ($total_page > 1)
echo $affiche;
?>
Remarque de mise à jour
Changements dans la version III
- L’appel de fonction qui provoquait la Fatal error : Call to undefined function : getarticlelinks() sur certains sites a été supprimé et remplacé par un fichier inclus (article-pagine.inc) qui contient le code (qui n’est donc plus dans mes_fonctions.php3)
- Une correction a été apportée au code qui obligeait à ce que la page traitée soit une page rubrique. Ce peut-être maintenant n’importe quelle boucle qui supporte le critère Spip {debut_xxx,b}
(relire cette doc sur spip.net ), une boucle mot, par exemple, ou encore une boucle SYNDIC_ARTICLES, comme sur cette page, etc. Il faut bien sur alors adapter les boucles spip au cas choisi
Pour ceux qui avaient implémenté la version II et qui souhaitent passer à la version III
1) Uploader le fichier « article-pagine.inc » dans le répertoire racine de votre site spip (là où il y a les squelettes .php3).
2) Dans le code du squelette .html à paginer, remplacer
les anciennes lignes :
// Param: compteur, nb_art_par_page, total, #ID_RUBRIQUE||#ID_MOT, "rubrique"||"mot"
echo getArticleLinks($compteur, $nb_art_par_page, $total, #ID_RUBRIQUE, "rubrique");
par ces nouvelles :
// Param: $idtype = #ID_RUBRIQUE|#ID_MOT, $type = "rubrique"|"mot"
$idtype=#ID_RUBRIQUE; $type = "rubrique";
include "article-pagine.inc";
3) Supprimer le code de la fonction « getArticleLinks(.. » de votre fichier mes_fonctions.php3. (ce dernier point n’est pas obligatoire, mais inutile de charger du code devenu inutile).
Discussions par date d’activité
12 discussions
Cet article a été mis à jour pour tenir compte des remarques et erreurs constatés par certains. C’est pourquoi, comme indiqué ici : « FAQ SPIP-Contrib », les messages des forums ont été supprimés.
Notez, comme l’avait dit François, qu’il existe également une autre solution de pagination : Xpagination
Quelqu’un a t’il le source de cette routine PHP
Apparemment le lien est cassé !!
Répondre à ce message
Bonjour à tous,
Comme Dany, j’utilise le script dans mot.php3, et aussi dans rubrique.php3. Dans cette dernière, pas de problème, cela fonctionne très bien. Par contre dans la page « mot » : aucune erreur mais la pagination ne s’affiche pas !!! La page se découpe bien à X articles mais sans pagination ? J’utilise une boucle « articles » avec id_mot.
Avec les variables $idtype = #ID_MOT et $type = « mot »
Si quelqu’un a une idée du problème !!
Merci par avance.
Francois.
Répondre à ce message
Ajouter un commentaire
Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :
Merci d’avance pour les personnes qui vous aideront !
Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.
Suivre les commentaires : |