Accueil > > > PAGINATION
PAGINATION
Information sur la source
Description
Petit script renvoyant un menu déroulant contenant les liens des diverses pages concernées, indexées par le champ choisi le cas échéant. Exemple fourni permettant d'inexer le menu déroulant en fonction du tri d'entete choisi (croissant ou décroissant). Attention penser à changer les params de connexion à la BDD Penser à executer le .sql dans le zip pour l'exemple Et joindre les img
Source
- <?php
- // Nb de ligne affichées par page
- $nblignes_aff = 20;
-
- // Ne pas toucher
- $clic = isset($_REQUEST["clic"]) ? $_REQUEST["clic"] : -1;
- $cle = isset($_REQUEST["cle"]) ? $_REQUEST["cle"] : 0;
- $ancien_cle = isset($_REQUEST["ancien_cle"]) ? $_REQUEST["ancien_cle"] : 0;
-
- // Libellé affiché (entete du tableau)
- $libelle = array("Nom", "Prénom", "Adresse", "Tél.", "Portable", "Fax");
- // Nom des champs de la base de données à afficher pour l'ordre du tri
- $ordre = array("CNOM", "CPRENOM", "CADR", "CTEL", "CPORT", "CFAX");
-
- // Ne pas toucher
- $vrai = false;
- $toto = isset($_REQUEST["G_debut"]) ? $_REQUEST["G_debut"] : "";
-
- print '
- <html>
- <head>
- <title>
- TEST
- </title>
- </head>
- <body>
- <form method="post" enctype="multipart/form-data" name="form1">
- ';
-
- if (isset($toto)) $vrai = true;
- if (!$vrai) {
- $clic = -1;
- $cle = 0;
- $G_debut = 0;
- }
-
- $pasbon = true;
- $order = "order by ".$ordre[$cle];
-
- if ($ancien_cle == $cle && $clic == 2) $order .= " desc";
-
- $BD = mysql_connect("localhost", "root", "");
- mysql_select_db("nombase", $BD);
-
- // Les requêtes simples ou avec jointures marchent sans problèmes
- // Il peut y avoir plus de champs sur la requête que dans le tableau libellé, mais seulement à la fin des autres désignés dans celui-ci
- $requete = "select CNOM, CPRENOM, CADR, CTEL, CPORT, CFAX from MATABLE $order";
- $result = mysql_query($requete, $BD);
- $rows = mysql_num_rows($result);
-
- if ($rows > 0) {
- list($debut, $fin, $pop) = @pagination($result, $nblignes_aff, basename($_SERVER["SCRIPT_NAME"])."?cle=$cle&clic=$clic&ancien_cle=$cle", $cle);
-
- $aff = "";
-
- for ($i=0;$i<count($libelle);$i++) {
- if (!$libelle[$i]) continue;
- if ($cle == $i) {
- $img = $clic == 2 ? " <img src=\"img/fleche_h.gif\">" : " <img src=\"img/fleche_b.gif\">";
- $leclic = 1 - $clic;
- } else {
- $leclic = -1;
- $img = "";
- }
-
- $aff .= "\t\t<th nowrap><a href=\"".basename($_SERVER["SCRIPT_NAME"])."?cle=$i&clic=$leclic&G_debut=$debut&ancien_cle=$cle\">".$libelle[$i]."</a>$img</th>\n";
- }
-
- $aff = "<br>\n<table border=\"0\" align=\"center\" width=\"90%\">\n\t<tr>\n".$aff."\t</tr>\n";
-
- if ($debut < $fin) {
- for ($i=$debut;$i<$fin;$i++) {
- if ($i % 2 == 0) $couleur = "'#C6CDC5'";
- else $couleur = "''";
-
- $temp = mysql_fetch_row($result);
- $aff2 = "";
-
- for ($j=0;$j<count($temp);$j++) {
- if (Empty($libelle[$j])) continue;
-
- $aff2 .= "\t\t<td nowrap>".$temp[$j]."</td>\n";
- }
-
- $aff2 = "<tr bgcolor=$couleur>\n".$aff2."</tr>\n";
- $aff .= $aff2;
- }
- }
- } else {
- $pasbon = false;
- $erreur = "Il n'y a aucun contact";
- }
- if ($pasbon) print "<br>$pop$aff\n</table>";
- else print "<center><font color=\"red\"><h4>$erreur</h4></font></center>";
-
- print '
- <input type="hidden" name="ancien_cle" value="$cle">
- <input type="hidden" name="clic" value="$clic">
- </form>
- </body>
- </html>
- ';
-
- mysql_close($BD);
-
- /*
- Usage :
- list($debut, $fin, $popup) = @pagination($requ, $nbaff, $param, $cle, $debut);
-
- $requ est l'identifiant de la requête à savoir :
- ex: $requ = mysql_query("select * from truc where machin=chose", $BD);
-
- $nbaff est le nombre de ligne affichable par page
-
- $param les paramètres à passer ds l'url pour rester sur la page voulue, à savoir nomfich?param0=truc0¶m1=truc1
-
- $cle est le numéro de la position du champ de la sélection sur lequel l'index sera appliqué (optionnel)
-
- $debut démarre la sélection de la requête à $debut défaut = 0 (optionnel)
- */
- function pagination($requ, $nbaff, $param, $cle = 0, $debut = 0) {
- global $G_debut;
-
- $G_debut = isset($_REQUEST["G_debut"]) ? $_REQUEST["G_debut"] : $debut;
- $nblignes_aff = $nbaff;
- $nbrow = mysql_num_rows($requ);
- $nbpage = $nbrow / $nblignes_aff > intVal($nbrow / $nblignes_aff) ? intVal($nbrow / $nblignes_aff) + 1 : intVal($nbrow / $nblignes_aff);
- $menu = "";
- $G_fin = 0;
-
- if ($nbrow > 0) {
- if ($nbpage > 1) {
- $lasituation = array();
- $inc = 0;
- $j = 1;
-
- while ($valeurs = mysql_fetch_row($requ)) {
- if ($inc % $nblignes_aff == 0) $lasituation[$j] = "$valeurs[$cle] --> ";
- if (($inc % (($nblignes_aff * $j) - 1) == 0 && $inc != 0) || $inc == ($nbrow - 1)) {
- $lasituation[$j] .= $valeurs[$cle];
- $j++;
- }
- $inc++;
- }
-
- mysql_data_seek($requ, $G_debut);
- $nb = 0;
- $popupmenu = "<SELECT NAME=\"pagination\" onChange=\"document.location=this.options[this.selectedIndex].value\">\n";
-
- for ($i=1;$i<=$nbpage;$i++) {
- if ($nb == $G_debut) {
- $popupmenu .= "<OPTION VALUE=\"0\" selected>page $i : $lasituation[$i]\n";
- } else {
- $popupmenu .= "<OPTION VALUE=\"$param&G_debut=$nb\">page $i : $lasituation[$i]\n";
- }
- $nb += $nblignes_aff;
- }
-
- $popupmenu .= "</SELECT>\n";
-
- $menu = "<center>$popupmenu<br><b>".($G_debut + $nblignes_aff > $nbrow?$nbrow:$G_debut + $nblignes_aff)." / $nbrow</b></center>";
- }
-
- $G_fin = $nbrow < $G_debut + $nblignes_aff ? $nbrow : $G_debut + $nblignes_aff;
- }
-
- return array($G_debut, $G_fin, $menu);
- }
- ?>
<?php
// Nb de ligne affichées par page
$nblignes_aff = 20;
// Ne pas toucher
$clic = isset($_REQUEST["clic"]) ? $_REQUEST["clic"] : -1;
$cle = isset($_REQUEST["cle"]) ? $_REQUEST["cle"] : 0;
$ancien_cle = isset($_REQUEST["ancien_cle"]) ? $_REQUEST["ancien_cle"] : 0;
// Libellé affiché (entete du tableau)
$libelle = array("Nom", "Prénom", "Adresse", "Tél.", "Portable", "Fax");
// Nom des champs de la base de données à afficher pour l'ordre du tri
$ordre = array("CNOM", "CPRENOM", "CADR", "CTEL", "CPORT", "CFAX");
// Ne pas toucher
$vrai = false;
$toto = isset($_REQUEST["G_debut"]) ? $_REQUEST["G_debut"] : "";
print '
<html>
<head>
<title>
TEST
</title>
</head>
<body>
<form method="post" enctype="multipart/form-data" name="form1">
';
if (isset($toto)) $vrai = true;
if (!$vrai) {
$clic = -1;
$cle = 0;
$G_debut = 0;
}
$pasbon = true;
$order = "order by ".$ordre[$cle];
if ($ancien_cle == $cle && $clic == 2) $order .= " desc";
$BD = mysql_connect("localhost", "root", "");
mysql_select_db("nombase", $BD);
// Les requêtes simples ou avec jointures marchent sans problèmes
// Il peut y avoir plus de champs sur la requête que dans le tableau libellé, mais seulement à la fin des autres désignés dans celui-ci
$requete = "select CNOM, CPRENOM, CADR, CTEL, CPORT, CFAX from MATABLE $order";
$result = mysql_query($requete, $BD);
$rows = mysql_num_rows($result);
if ($rows > 0) {
list($debut, $fin, $pop) = @pagination($result, $nblignes_aff, basename($_SERVER["SCRIPT_NAME"])."?cle=$cle&clic=$clic&ancien_cle=$cle", $cle);
$aff = "";
for ($i=0;$i<count($libelle);$i++) {
if (!$libelle[$i]) continue;
if ($cle == $i) {
$img = $clic == 2 ? " <img src=\"img/fleche_h.gif\">" : " <img src=\"img/fleche_b.gif\">";
$leclic = 1 - $clic;
} else {
$leclic = -1;
$img = "";
}
$aff .= "\t\t<th nowrap><a href=\"".basename($_SERVER["SCRIPT_NAME"])."?cle=$i&clic=$leclic&G_debut=$debut&ancien_cle=$cle\">".$libelle[$i]."</a>$img</th>\n";
}
$aff = "<br>\n<table border=\"0\" align=\"center\" width=\"90%\">\n\t<tr>\n".$aff."\t</tr>\n";
if ($debut < $fin) {
for ($i=$debut;$i<$fin;$i++) {
if ($i % 2 == 0) $couleur = "'#C6CDC5'";
else $couleur = "''";
$temp = mysql_fetch_row($result);
$aff2 = "";
for ($j=0;$j<count($temp);$j++) {
if (Empty($libelle[$j])) continue;
$aff2 .= "\t\t<td nowrap>".$temp[$j]."</td>\n";
}
$aff2 = "<tr bgcolor=$couleur>\n".$aff2."</tr>\n";
$aff .= $aff2;
}
}
} else {
$pasbon = false;
$erreur = "Il n'y a aucun contact";
}
if ($pasbon) print "<br>$pop$aff\n</table>";
else print "<center><font color=\"red\"><h4>$erreur</h4></font></center>";
print '
<input type="hidden" name="ancien_cle" value="$cle">
<input type="hidden" name="clic" value="$clic">
</form>
</body>
</html>
';
mysql_close($BD);
/*
Usage :
list($debut, $fin, $popup) = @pagination($requ, $nbaff, $param, $cle, $debut);
$requ est l'identifiant de la requête à savoir :
ex: $requ = mysql_query("select * from truc where machin=chose", $BD);
$nbaff est le nombre de ligne affichable par page
$param les paramètres à passer ds l'url pour rester sur la page voulue, à savoir nomfich?param0=truc0¶m1=truc1
$cle est le numéro de la position du champ de la sélection sur lequel l'index sera appliqué (optionnel)
$debut démarre la sélection de la requête à $debut défaut = 0 (optionnel)
*/
function pagination($requ, $nbaff, $param, $cle = 0, $debut = 0) {
global $G_debut;
$G_debut = isset($_REQUEST["G_debut"]) ? $_REQUEST["G_debut"] : $debut;
$nblignes_aff = $nbaff;
$nbrow = mysql_num_rows($requ);
$nbpage = $nbrow / $nblignes_aff > intVal($nbrow / $nblignes_aff) ? intVal($nbrow / $nblignes_aff) + 1 : intVal($nbrow / $nblignes_aff);
$menu = "";
$G_fin = 0;
if ($nbrow > 0) {
if ($nbpage > 1) {
$lasituation = array();
$inc = 0;
$j = 1;
while ($valeurs = mysql_fetch_row($requ)) {
if ($inc % $nblignes_aff == 0) $lasituation[$j] = "$valeurs[$cle] --> ";
if (($inc % (($nblignes_aff * $j) - 1) == 0 && $inc != 0) || $inc == ($nbrow - 1)) {
$lasituation[$j] .= $valeurs[$cle];
$j++;
}
$inc++;
}
mysql_data_seek($requ, $G_debut);
$nb = 0;
$popupmenu = "<SELECT NAME=\"pagination\" onChange=\"document.location=this.options[this.selectedIndex].value\">\n";
for ($i=1;$i<=$nbpage;$i++) {
if ($nb == $G_debut) {
$popupmenu .= "<OPTION VALUE=\"0\" selected>page $i : $lasituation[$i]\n";
} else {
$popupmenu .= "<OPTION VALUE=\"$param&G_debut=$nb\">page $i : $lasituation[$i]\n";
}
$nb += $nblignes_aff;
}
$popupmenu .= "</SELECT>\n";
$menu = "<center>$popupmenu<br><b>".($G_debut + $nblignes_aff > $nbrow?$nbrow:$G_debut + $nblignes_aff)." / $nbrow</b></center>";
}
$G_fin = $nbrow < $G_debut + $nblignes_aff ? $nbrow : $G_debut + $nblignes_aff;
}
return array($G_debut, $G_fin, $menu);
}
?>
Conclusion
Utile pour les affichages de tableau, dont les entêtes sont utilisées pour le tri des données, le menu déroulant s'indexe en fonction de cela.
Historique
- 23 février 2005 18:50:54 :
- Petite amélioration avec exemple accompagnant
Ajout capture écran
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
[SHAREPOINT 2010] CRéER ET PACKAGER UNE APPLICATION SILVERLIGHT POUR SHAREPOINT 2010[SHAREPOINT 2010] CRéER ET PACKAGER UNE APPLICATION SILVERLIGHT POUR SHAREPOINT 2010 par neodante
L'intégration native de Silverlight dans SharePoint 2010 représente une avancée majeure dans la conception des applications sur la plateforme SharePoint. Et pour cause, Silverlight repousse les limites du Web de SharePoint en offrant une expérience plus r...
Cliquez pour lire la suite de l'article par neodante [MIX10] KEYNOTE PREMIèRE JOURNéE - WINDOWS PHONE 7 ET SILVERLIGHT 4[MIX10] KEYNOTE PREMIèRE JOURNéE - WINDOWS PHONE 7 ET SILVERLIGHT 4 par cyril
Comme l'année dernière, me revoici à Las Vegas pour Mix10. Ce matin a eu lieu le premier keynote animé par Scott Guthrie. Le keynote s'est déroulé en 2 parties : Silverlight 4.0 et Windows Phone 7 Silverlight 4.0 Le taux de pénétration de Silverli...
Cliquez pour lire la suite de l'article par cyril [MIX10] RELEASE CANDIDATE DE SILVERLIGHT 4 ET RIA SERVICES[MIX10] RELEASE CANDIDATE DE SILVERLIGHT 4 ET RIA SERVICES par Audrey
C'est enfin officiel, grâce au MIX 2010, les Release Candidate de Silverlight 4 et de RIA Services sont sorties ! Pour les télécharger, voici les liens : Silverlight 4 RC : http://silverlight.net/getstarted/silverlight-4/ RIA Services RC : http://www.micr...
Cliquez pour lire la suite de l'article par Audrey PREMIERES IMPRESSIONS SUR WINDOWS PHONE 7PREMIERES IMPRESSIONS SUR WINDOWS PHONE 7 par odewit
Il est toujours passionnant de decouvrir une nouvelle plate-forme. C'est bien entendu le cas pour Windows Phone 7. Mais au-dela de la passion technique, j'ai le sentiment qu'il s'agit d'un coup de maitre en termes d'ergonomie (tres fluide et epuree) e...
Cliquez pour lire la suite de l'article par odewit [WINDOWSPHONE7] LECTEUR DE FLUX RSS[WINDOWSPHONE7] LECTEUR DE FLUX RSS par Vko
Parce que j'aime pas tester à moitié, je me suis amusé à développer un petit lecteur de flux RSS avec un look qui vous rappellera surement quelque chose :) La RC de Visual Studio est plutôt molle mais fonctionne correctement. L'émulateur est pas...
Cliquez pour lire la suite de l'article par Vko
Forum
RE : GOOGLEMAPRE : GOOGLEMAP par GREGGRAPH
Cliquez pour lire la suite par GREGGRAPH
Logiciels
Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods Konvertor (4.00)KONVERTOR (4.00)Le logiciel est un gestionnaire multimedia affichant, jouant et convertissant plus de 2000 format... Cliquez pour télécharger Konvertor
Comparez les prix

HTC Magic
Entre 429€ et 429€
|