Domanda

Quindi lo sto facendo in PHP ma è un problema logico, quindi proverò a scriverlo il più genericamente possibile.

Per iniziare ecco come funziona questo script di impaginazione:

  1. per ( disegna i collegamenti delle prime tre pagine )
  2. if ( disegna ellissi (...) se ci sono pagine tra le pagine n. 1 e le pagine n. 3 )
  3. per ( disegna la pagina corrente e due pagine su ciascun lato dei collegamenti )
  4. if ( draw elipsis (...) se ci sono pagine tra le pagine # 3 e # 5 )
  5. per ( traccia i collegamenti delle tre pagine finali )

Il problema è che quando ci sono basse quantità di pagine (ho notato questo quando il conteggio delle pagine era a 10) ci dovrebbero essere dei puntini di sospensione ma nessuno viene disegnato.

Sul codice:

$page_count = 10; //in actual code this is set properly
$current_page = 1; //in actual code this is set properly

for ($i = 1;$i <= 3;$i++)
{
    if ($page_count >= $i)
        echo $i;
}

if ($page_count > 3 && $current_page >= 7)
    echo "...";

for ($i = $current_page - 2;$i <= current_page + 2;$i++)
{
    if ($i > 3 && $i < $page_count - 2)
        echo $i;
}

if ($page_count > 13 && $current_page < $page_count - 5)
    echo "...";

for ($i = $page_count - 2;$i <= $page_count;$i++)
{
    if ($page_count > 3)
        echo $i;
}

Quindi immagino che l'idea migliore sarebbe quella di modificare una delle due ellissi se le istruzioni includessero un caso come questo, tuttavia ho provato e sono sconcertato.

Inoltre, tieni presente che ho condensato questo codice per motivi di leggibilità, quindi per favore non dare suggerimenti come "quelli per i loop sono inefficaci perché ricalcoleranno current_page - 2 per ogni iterazione" perché lo so :)


Per coloro che vogliono vedere una ripartizione del funzionamento di questa logica, ecco un esempio di output (modificato) con iterazione di $ page_count e $ current_page. http://rafb.net/p/TNa56h71.html

È stato utile?

Soluzione

<?php

/**
 * windowsize must be odd
 *
 * @param int $totalItems 
 * @param int $currentPage 
 * @param int $windowSize 
 * @param int $anchorSize 
 * @param int $itemsPerPage 
 * @return void
 */
function paginate($totalItems, $currentPage=1, $windowSize=3, $anchorSize=3, $itemsPerPage=10) {
    $halfWindowSize = ($windowSize-1)/2;

    $totalPages = ceil($totalItems / $itemsPerPage);
    $elipsesCount = 0;
    for ($page = 1; $page <= $totalPages; $page++) {
        // do we display a link for this page or not?
        if ( $page <= $anchorSize ||  
            $page > $totalPages - $anchorSize ||
            ($page >= $currentPage - $halfWindowSize &&
            $page <= $currentPage + $halfWindowSize) ||
            ($page == $anchorSize + 1 &&
             $page == $currentPage - $halfWindowSize - 1) ||
            ($page == $totalPages - $anchorSize &&  
             $page == $currentPage + $halfWindowSize + 1 ))
        {
            $elipsesCount = 0;
            if ($page == $currentPage)
                echo ">$page< ";
            else
                echo "[$page] ";
        // if not, have we already shown the elipses?
        } elseif ($elipsesCount == 0) {
            echo "... ";
            $elipsesCount+=1; // make sure we only show it once
        }
    }
    echo "\n";
}

//
// Examples and output
//

paginate(1000, 1, 3, 3);
// >1< [2] [3] ... [98] [99] [100] 

paginate(1000, 7, 3, 3);
// [1] [2] [3] ... [6] >7< [8] ... [98] [99] [100] 

paginate(1000, 4, 3, 3);
// [1] [2] [3] >4< [5] ... [98] [99] [100] 

paginate(1000, 32, 3, 3);
// [1] [2] [3] ... [31] >32< [33] ... [98] [99] [100] 

paginate(1000, 42, 7, 2);
// [1] [2] ... [39] [40] [41] >42< [43] [44] [45] ... [99] [100] 

Altri suggerimenti

Questa è probabilmente una soluzione complicata, ma funziona.

Ho usato un array qui invece di limitarmi a stampare, il che mi consente di fare il do-over " la logica.

Parte del problema si verifica quando " sinistra e destra della pagina " coincide con le spalle sinistra e destra.

function cdotinator ( $current_page, $page_count ) 
{
  $stepsize = 3; 
  $elipse = '...';
  # Simple Case. 
  if ( $page_count <= 2 * $stepsize )
  {
    $out = range( 1, $page_count );
    $out[$current_page - 1 ] = '*' . $current_page . '*';
    return $out;
  }
  #Complex Case
  # 1) Create All Pages
  $out = range( 1, $page_count ); 
  # 2 ) Replace "middle" pages with "." placeholder elements 
  for( $i = $stepsize+1 ; $i <= ( $page_count - $stepsize ) ; $i ++ )
  {
    $out[ $i - 1 ] = '.' ; 
  }
  # 3.1 ) Insert the pages around the current page 
  for( $i =  max(1,( $current_page - floor($stepsize / 2) )) ;
       $i <= min( $page_count,( $current_page + floor( $stepsize/2))); 
       $i ++ )
  {
    $out[ $i - 1] = $i;
  }
  # 3.2 Bold Current Item
  $out[ $current_page - 1 ] = '*' . $current_page . '*' ; 

  # 4 ) Grep out repeated '.' sequences and replace them with elipses 
  $out2 = array(); 
  foreach( $out as $i => $v )
  {
    #  end, current  == peek() 
    end($out2);
    if( current($out2) == $elipse and $v == '.' )
    {
        continue;
    }
    if( $v == '.' )
    {
      $out2[] = $elipse; 
      continue;
    }
    $out2[]= $v;
  }

  return $out2;

}

L'output può essere visualizzato qui: http://dpaste.com/92648/

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top