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)

È stato utile?

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);
    }
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top