Domanda
lt &; Lt &; 1 2 3 4 ... 15 16 17 ... 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 5 6 7 ... 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 ... 44 45 46 47 48 49 50 & Gt; & Gt;
(il grassetto è la pagina selezionata)
Esiste una logica di mannaia che crea impaginazione in scala come questa? Ho creato uno di questi prima, ma è finito come un casino di dichiarazioni logiche.
La lingua che sto facendo in questo momento è PHP ma se hai esempi o suggerimenti per qualsiasi lingua, sarebbe apprezzata.
Per ridimensionamento intendo quando ci sono solo poche pagine. L'impaginazione lo mostra.
lt &; Lt &; 1 2 3 4 5 6 7 & Gt; & Gt;
Man mano che il numero di pagine aumenta fino a un certo punto, l'impaginazione smette di mostrare tutti i numeri e inizia a dividerli.
lt &; Lt &; 1 2 3 4 ... 47 48 49 50 > >
lt &; Lt &; 1 2 3 4 5 6 ... 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 5 6 7 8 ... 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 .. 7 8 9 ... 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 .. 15 16 17 ... 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 ... 44 45 46 47 48 49 50 & Gt; & Gt;
lt &; Lt &; 1 2 3 4 ... 47 48 49 50 & Gt; & Gt;
(nota, i numeri effettivi e quanti ne mostra prima e dopo non sono rilevanti)
Soluzione
Ci scusiamo per il BLOB di codice, ma qui va. Spero che i commenti siano sufficienti per dirti come funziona - se lasci un commento e potrei aggiungerne un po 'di più.
/**
* Get a spread of pages, for when there are too many to list in a single <select>
* Adapted from phpMyAdmin common.lib.php PMA_pageselector function
*
* @param integer total number of items
* @param integer the current page
* @param integer the total number of pages
* @param integer the number of pages below which all pages should be listed
* @param integer the number of pages to show at the start
* @param integer the number of pages to show at the end
* @param integer how often to show pages, as a percentage
* @param integer the number to show around the current page
*/
protected function pages($rows, $pageNow = 1, $nbTotalPage = 1, $showAll = 200, $sliceStart = 5, $sliceEnd = 5, $percent = 20, $range = 10)
{
if ($nbTotalPage < $showAll)
return range(1, $nbTotalPage);
// Always show the first $sliceStart pages
$pages = range(1, $sliceStart);
// Always show last $sliceStart pages
for ($i = $nbTotalPage - $sliceEnd; $i <= $nbTotalPage; $i++)
$pages[] = $i;
$i = $sliceStart;
$x = $nbTotalPage - $sliceEnd;
$met_boundary = false;
while ($i <= $x)
{
if ($i >= ($pageNow - $range) && $i <= ($pageNow + $range))
{
// If our pageselector comes near the current page, we use 1
// counter increments
$i++;
$met_boundary = true;
}
else
{
// We add the percentate increment to our current page to
// hop to the next one in range
$i = $i + floor($nbTotalPage / $percent);
// Make sure that we do not cross our boundaries.
if ($i > ($pageNow - $range) && !$met_boundary)
$i = $pageNow - $range;
}
if ($i > 0 && $i <= $x)
$pages[] = $i;
}
// Since because of ellipsing of the current page some numbers may be double,
// we unify our array:
sort($pages);
return array_unique($pages);
}