Accueil > > > CLASS DE PAGINATION
CLASS DE PAGINATION
Information sur la source
Description
J'avais déjà fais une source d'une fonction de pagination (http://www.phpcs.com/code.aspx?ID=40509) et donc voilà une Class que j'ai amélioré (enfin j'espère XD) et rajouté quelques petits trucs ici et là.
Source
- <?php
- class Pagination
- {
- private $nb_datas;
- private $nb_pages;
- private $current_page = 1;
- private $start_offset = 0;
-
- private $link;
- private $next_page;
- private $previous_page;
- private $first_page;
- private $last_page;
-
- /**
- * @var nombre de données sur une seule page
- * @access private
- */
- private $data_per_page = 10;
-
- /**
- * @var nombre de liens s'affichant sur les cotés de la page courante
- * @access private
- */
- private $nb_link_per_page = 5;
-
- /**
- * @var url de la page actuelle
- * @access private
- */
- private $url = '';
-
- /**
- * @var activation de l'url rewriting
- * @access private
- */
- private $url_rewriting = false;
-
- /**
- * @var nom de la variable $_GET
- * @access private
- */
- private $var_page = 'page';
-
- /**
- * @var separateur qui sépare (logique haha...) les liens entre eux
- * @access private
- */
- private $separator = '|';
-
- /**
- * @var nombre d'espace avant le separateur
- * @access private
- */
- private $space_before = 1;
-
- /**
- * @var nombre d'espace après le separateur
- * @access private
- */
- private $space_after = 1;
-
- /**
- * @var options disponibles
- * @access private
- */
- private $options = array(
- 'nb_datas',
- 'data_per_page',
- 'nb_link_per_page',
- 'url',
- 'url_rewriting',
- 'var_page',
- 'space_before',
- 'space_after',
- 'separator'
- );
-
- /**
- * Constructeur de la class avec en argument les options choisis
- */
- public function __construct($options = null)
- {
- $this->generateOptions($options);
- $this->generatePages();
- $this->generateLink();
- }
-
- /**
- * Génère les options
- */
- private function generateOptions($options)
- {
- foreach ($options as $key => $value)
- {
- if (in_array($key, $this->options) && !is_null($value))
- {
- $this->$key = $value;
- }
- }
- }
-
- /**
- * Génère le nombre de pages, la page courante et le premiers offset
- */
- private function generatePages()
- {
- $this->nb_pages = ceil($this->nb_datas / $this->data_per_page);
- $this->current_page = !empty($_GET[$this->var_page]) && is_numeric($_GET[$this->var_page]) && $_GET[$this->var_page] < $this->nb_pages + 1 ? $_GET[$this->var_page] : 1;
- $this->start_offset = ($this->current_page - 1) * $this->data_per_page;
- }
-
- /**
- * Génère les liens
- */
- private function generateLink()
- {
- if ($this->url_rewriting)
- {
- $this->link = $this->url;
-
- $this->next_page = sprintf($this->url, $this->current_page + 1);
- $this->previous_page = sprintf($this->url, $this->current_page - 1);
- $this->first_page = sprintf($this->url, 1);
- $this->last_page = sprintf($this->url, $this->nb_pages);
- }
- else
- {
- $this->link = strstr($this->url, '?') ? '&' : '?';
- $this->link .= $this->var_page . '=';
-
- $this->next_page = $this->link . ($this->current_page + 1);
- $this->previous_page = $this->link . ($this->current_page - 1);
- $this->first_page = $this->link . 1;
- $this->last_page = $this->link . $this->nb_pages;
- }
- }
-
- /**
- * Retourne le lien de la première page si la page courante est supérieur à 3 et celui de la page précédente
- *
- * @return string
- */
- public function getFirstLinks()
- {
- $display = '';
-
- if ($this->current_page != 1)
- {
- if ($this->current_page >= 3)
- {
- $display .= ' <a href="' . $this->first_page . '"><<</a> ';
- }
-
- $display .= ' <a href="' . $this->previous_page . '" ><</a> ';
-
- return $display;
- }
- }
-
- /**
- * Retourne le lien de la page suivante et celui de la dernière page si la page courante n'est pas égale au nombre de pages
- *
- * @return string
- */
- public function getLastLinks()
- {
- $display = '';
-
- if ($this->current_page != $this->nb_pages)
- {
- $display .= ' <a href="' . $this->next_page . '" >></a> ';
-
- if ($this->current_page <= $this->nb_pages - 2)
- {
- $display .= ' <a href="' . $this->last_page . '">>></a> ';
- }
-
- return $display;
- }
- }
-
- /**
- * Retourne la liste des liens avec le séparateur si il n'est pas vide : 0 | 1 | 2 | 3 | 4
- *
- * @return string
- */
- public function getLinks()
- {
- $display = '';
-
- for ($i = 1; $i <= $this->nb_pages; $i++)
- {
- if ($i - 1 < ($this->current_page + $this->nb_link_per_page) && $i + 1 > ($this->current_page - $this->nb_link_per_page))
- {
- if ($i == $this->current_page)
- {
- $display .= '<span>' . $i . '</span>';
- }
- else
- {
- if ($this->url_rewriting)
- {
- $url = sprintf($this->link, $i);
- }
- else
- {
- $url = $this->link . $i;
- }
-
- $display .= '<a href="' . $url . '">' . $i . '</a>';
- }
-
- if ($i != $this->current_page + $this->nb_link_per_page && $i != $this->nb_pages)
- {
- for ($j = 0; $j <= $this->space_before; $j++)
- {
- $display .= ' ';
- }
-
- $display .= $this->separator;
-
- for ($j = 0; $j <= $this->space_after; $j++)
- {
- $display .= ' ';
- }
- }
- }
- }
-
- return $display;
- }
-
- public function __get($name)
- {
- if (property_exists($this, $name))
- {
- return $this->$name;
- }
- }
-
- public function __set($name, $value)
- {
- if (property_exists($this, $name))
- {
- $this->$name = $value;
- }
- }
- }
- ?>
-
- <p>Petit exemple :</p>
-
- <?php
- /* Avec un array
- $datas = array();
-
- for ($i = 1; $i <= 10000; $i++)
- {
- $datas[] = 'niah_' . $i;
- }
- */
-
- // Avec une base de donnée
- $connect = mysql_connect('localhost', 'root', '');
- mysql_select_db('test', $connect);
-
- $query_count = mysql_query('SELECT COUNT(id) AS nb FROM news');
- $count = mysql_result($query_count, 0);
- //
-
- $options = array(
- 'nb_datas' => $count, // Avec une base de donnée
- // 'nb_datas' => count($datas), // Avec un array
- 'data_per_page' => 20,
- 'nb_link_per_page' => 10,
- 'url' => $_SERVER['PHP_SELF'], // Sans url rewriting
- // 'url' => 'index-%d.html', // Avec url rewriting
- // 'url_rewriting' => true, // Avec url rewriting
- 'var_page' => 'p'
- );
-
- $pagination = new Pagination($options);
- $pagination->separator = '-';
-
- /* Avec un array
- $datas = array_slice($datas, $pagination->start_offset, $pagination->data_per_page);
-
- foreach ($datas as $data)
- {
- echo $data . '<br />';
- }
- */
-
- // Avec une base de donnée
- $query = mysql_query('SELECT id, title, content FROM news LIMIT ' . $pagination->start_offset . ', ' . $pagination->data_per_page);
-
- while ($row = mysql_fetch_assoc($query))
- {
- echo $row['id'] . '<br />';
- }
- //
-
- echo '<br />Pages (' . $pagination->nb_pages . ' pages pour ' . $pagination->nb_datas . ' résultats) : ' . $pagination->getFirstLinks() . $pagination->getLinks() . $pagination->getLastLinks();
- ?>
<?php
class Pagination
{
private $nb_datas;
private $nb_pages;
private $current_page = 1;
private $start_offset = 0;
private $link;
private $next_page;
private $previous_page;
private $first_page;
private $last_page;
/**
* @var nombre de données sur une seule page
* @access private
*/
private $data_per_page = 10;
/**
* @var nombre de liens s'affichant sur les cotés de la page courante
* @access private
*/
private $nb_link_per_page = 5;
/**
* @var url de la page actuelle
* @access private
*/
private $url = '';
/**
* @var activation de l'url rewriting
* @access private
*/
private $url_rewriting = false;
/**
* @var nom de la variable $_GET
* @access private
*/
private $var_page = 'page';
/**
* @var separateur qui sépare (logique haha...) les liens entre eux
* @access private
*/
private $separator = '|';
/**
* @var nombre d'espace avant le separateur
* @access private
*/
private $space_before = 1;
/**
* @var nombre d'espace après le separateur
* @access private
*/
private $space_after = 1;
/**
* @var options disponibles
* @access private
*/
private $options = array(
'nb_datas',
'data_per_page',
'nb_link_per_page',
'url',
'url_rewriting',
'var_page',
'space_before',
'space_after',
'separator'
);
/**
* Constructeur de la class avec en argument les options choisis
*/
public function __construct($options = null)
{
$this->generateOptions($options);
$this->generatePages();
$this->generateLink();
}
/**
* Génère les options
*/
private function generateOptions($options)
{
foreach ($options as $key => $value)
{
if (in_array($key, $this->options) && !is_null($value))
{
$this->$key = $value;
}
}
}
/**
* Génère le nombre de pages, la page courante et le premiers offset
*/
private function generatePages()
{
$this->nb_pages = ceil($this->nb_datas / $this->data_per_page);
$this->current_page = !empty($_GET[$this->var_page]) && is_numeric($_GET[$this->var_page]) && $_GET[$this->var_page] < $this->nb_pages + 1 ? $_GET[$this->var_page] : 1;
$this->start_offset = ($this->current_page - 1) * $this->data_per_page;
}
/**
* Génère les liens
*/
private function generateLink()
{
if ($this->url_rewriting)
{
$this->link = $this->url;
$this->next_page = sprintf($this->url, $this->current_page + 1);
$this->previous_page = sprintf($this->url, $this->current_page - 1);
$this->first_page = sprintf($this->url, 1);
$this->last_page = sprintf($this->url, $this->nb_pages);
}
else
{
$this->link = strstr($this->url, '?') ? '&' : '?';
$this->link .= $this->var_page . '=';
$this->next_page = $this->link . ($this->current_page + 1);
$this->previous_page = $this->link . ($this->current_page - 1);
$this->first_page = $this->link . 1;
$this->last_page = $this->link . $this->nb_pages;
}
}
/**
* Retourne le lien de la première page si la page courante est supérieur à 3 et celui de la page précédente
*
* @return string
*/
public function getFirstLinks()
{
$display = '';
if ($this->current_page != 1)
{
if ($this->current_page >= 3)
{
$display .= ' <a href="' . $this->first_page . '"><<</a> ';
}
$display .= ' <a href="' . $this->previous_page . '" ><</a> ';
return $display;
}
}
/**
* Retourne le lien de la page suivante et celui de la dernière page si la page courante n'est pas égale au nombre de pages
*
* @return string
*/
public function getLastLinks()
{
$display = '';
if ($this->current_page != $this->nb_pages)
{
$display .= ' <a href="' . $this->next_page . '" >></a> ';
if ($this->current_page <= $this->nb_pages - 2)
{
$display .= ' <a href="' . $this->last_page . '">>></a> ';
}
return $display;
}
}
/**
* Retourne la liste des liens avec le séparateur si il n'est pas vide : 0 | 1 | 2 | 3 | 4
*
* @return string
*/
public function getLinks()
{
$display = '';
for ($i = 1; $i <= $this->nb_pages; $i++)
{
if ($i - 1 < ($this->current_page + $this->nb_link_per_page) && $i + 1 > ($this->current_page - $this->nb_link_per_page))
{
if ($i == $this->current_page)
{
$display .= '<span>' . $i . '</span>';
}
else
{
if ($this->url_rewriting)
{
$url = sprintf($this->link, $i);
}
else
{
$url = $this->link . $i;
}
$display .= '<a href="' . $url . '">' . $i . '</a>';
}
if ($i != $this->current_page + $this->nb_link_per_page && $i != $this->nb_pages)
{
for ($j = 0; $j <= $this->space_before; $j++)
{
$display .= ' ';
}
$display .= $this->separator;
for ($j = 0; $j <= $this->space_after; $j++)
{
$display .= ' ';
}
}
}
}
return $display;
}
public function __get($name)
{
if (property_exists($this, $name))
{
return $this->$name;
}
}
public function __set($name, $value)
{
if (property_exists($this, $name))
{
$this->$name = $value;
}
}
}
?>
<p>Petit exemple :</p>
<?php
/* Avec un array
$datas = array();
for ($i = 1; $i <= 10000; $i++)
{
$datas[] = 'niah_' . $i;
}
*/
// Avec une base de donnée
$connect = mysql_connect('localhost', 'root', '');
mysql_select_db('test', $connect);
$query_count = mysql_query('SELECT COUNT(id) AS nb FROM news');
$count = mysql_result($query_count, 0);
//
$options = array(
'nb_datas' => $count, // Avec une base de donnée
// 'nb_datas' => count($datas), // Avec un array
'data_per_page' => 20,
'nb_link_per_page' => 10,
'url' => $_SERVER['PHP_SELF'], // Sans url rewriting
// 'url' => 'index-%d.html', // Avec url rewriting
// 'url_rewriting' => true, // Avec url rewriting
'var_page' => 'p'
);
$pagination = new Pagination($options);
$pagination->separator = '-';
/* Avec un array
$datas = array_slice($datas, $pagination->start_offset, $pagination->data_per_page);
foreach ($datas as $data)
{
echo $data . '<br />';
}
*/
// Avec une base de donnée
$query = mysql_query('SELECT id, title, content FROM news LIMIT ' . $pagination->start_offset . ', ' . $pagination->data_per_page);
while ($row = mysql_fetch_assoc($query))
{
echo $row['id'] . '<br />';
}
//
echo '<br />Pages (' . $pagination->nb_pages . ' pages pour ' . $pagination->nb_datas . ' résultats) : ' . $pagination->getFirstLinks() . $pagination->getLinks() . $pagination->getLastLinks();
?>
Historique
- 28 décembre 2006 12:32:31 :
- Ajout de la documentation ainsi que d'un exemple
- 28 décembre 2006 14:56:45 :
- Rajout de mots clés :p
- 02 janvier 2007 17:49:41 :
- Après avoir lu les commentaires j'ai mis à jour ma source... a vous de me dire si cela vous convient mieux =)
- 08 février 2007 10:43:22 :
- Correction de bugs et mise à jour de l'exemple avec une base de donnée
- 16 mai 2007 14:51:57 :
- Petit bug pour l'url rewriting (les liens suivant, précédent... ne fonctionnaient pas) réglé
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Class POO retourné le nom de l'objet [ par MeTh ]
Bonjour,Comment retourné le nom de l'objet déclaré?exemple :$monobjet = new GridR();comment recuperé $monobjet dans ma class?Merci
Pagination de page... [ par AgentSmith ]
Salut à tous,Je souhaiterai avoir quelque indicationpour savoir si il y a une possibilité depaginer des pages avec la sortie de la base de donnée. Exe
probleme de classe en php [ par Elkaire ]
Donc voila mon probleme!!dans une premiere page je rensegne les insances de mon objet. Une fois renseigné je peux réutiliser les instances cet objet d
pagination sur une page php [ par hbib ]
salut,je souhaiterai savoir comment faire pour faire une pagination sur une page phpen effet jai un tableau qui affiche differente infos de ma base de
transferer une variable d'objet de page en page ?? [ par Arkko ]
slt ... j'aimerais savoir si y'a un moyen de transferer une variable d'objet d'une page a un autre ???exemple:1.php:<?MaClasse = new Maclasse;?>
Pagination avec PHP/MSAccess [ par le_freeman ]
Bonjour,je voulais savoir si certains d'entre vous pourraient me dire comment je pourrais faire un affichage page par page de données récupérées via P
Pagination avec nombre de pages [ par sebalex ]
Salut à tous,Voilà, j'ai une liste résultant d'une recherche. Cette liste se limite à 5 résultats par page. A présent, j
objet php5 surdéfinition de fonctions [ par poiuytrez3 ]
Bonjour, j'ai crée un objet php5 avec plusieurs membres privés. J'ai donc crée une fonction function __get($attribut){ return $this->attribut; } e
Objet de page en page la serialization ne suffit pas? [ par dracito ]
Bonjour, Nous avons programmé un site dont les scripts php utilisent des objets. Notre server local de test ne rencontre pas d'erreur pour nos scripts
pagination d'une longue page html sur plusieurs page [ par amer_ezahir ]
salut tout le monde le du ALLHTML svp j'ai besoin que vous m'aider à faire un style ou un code html qui permet d'afficher une longue page HTML su
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Forum
GOOGLE MAPGOOGLE MAP par fatmanajjar
Cliquez pour lire la suite par fatmanajjar
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|