Question

Donc, je le fais en PHP, mais c'est un problème de logique et je vais donc essayer de l'écrire aussi génériquement que possible.

Pour commencer, voici comment ce script de pagination fonctionne:

  1. pour ( dessiner les trois premières pages de liens )
  2. if ( dessinez des points de suspension (...) s'il y a des pages entre les pages de # 1 et de # 3 )
  3. pour ( dessine la page en cours et deux pages de chaque côté des liens )
  4. if ( dessinez des élipsis (...) s'il y a des pages entre les pages de # 3 et de # 5 )
  5. pour ( dessiner les derniers liens de trois pages )

Le problème est que, lorsque le nombre de pages est faible (je l’ai remarqué lorsque le nombre de pages était à 10), il devrait y avoir des points de suspension mais aucun n’est dessiné.

Sur le code:

$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;
}

Je pense donc que la meilleure idée serait de modifier l’un des deux points de suspension si les instructions incluent un cas comme celui-ci, mais j’ai essayé et je suis perplexe.

Notez également que j'ai condensé ce code pour des raisons de lisibilité. Ne donnez donc pas de conseils tels que "les boucles for sont inefficaces, car elles recalculeront current_page - 2 à chaque itération". parce que je sais:)

Pour ceux qui souhaitent voir comment cette logique fonctionne actuellement, voici un exemple de sortie (modifié) avec l'itération $ page_count et $ current_page. http://rafb.net/p/TNa56h71.html

Était-ce utile?

La solution

<?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] 

Autres conseils

Ceci est probablement une solution compliquée, mais cela fonctionne.

J'ai utilisé un tableau ici au lieu de simplement imprimer, ce qui me permet de "refaire" et de la logique.

Une partie du problème survient lorsque vous êtes "à gauche et à droite de la page". arrive à coïncider avec les épaules gauche et droite.

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;

}

La sortie est visible ici: http://dpaste.com/92648/

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top