v2.5.2
Giriş yap

Php sayfalama

merakli
1,867 defa görüntülendi ve 1 kişi tarafından değerlendirildi
<?php
    echo "Merhaba php sayfalama yapmak istiyorum yapıyorum ama istediğim gibi değil ben 
    [1][2[3][4][5]...[20] gibisinden sıralama yaptırmak istiyorum nasıl yaparım sizce
    ";
?>
Benim kodlarım bu şekilde
<?php
    $sayfada = 16; 
    $sorgu=$db->prepare("SELECT * from urunler");
    $sorgu->execute();
    $toplam_icerik=$sorgu->rowCount();
    $toplam_sayfa = ceil($toplam_icerik / $sayfada);
                      // eğer sayfa girilmemişse 1 varsayalım.
    $sayfa = isset($_GET['sayfa']) ? (int) $_GET['sayfa'] : 1;
                  // eğer 1'den küçük bir sayfa sayısı girildiyse 1 yapalım.
    if($sayfa < 1) $sayfa = 1; 
                  // toplam sayfa sayımızdan fazla yazılırsa en son sayfayı varsayalım.
    if($sayfa > $toplam_sayfa) $sayfa = $toplam_sayfa; 
    $limit = ($sayfa - 1) * $sayfada;

    $urunsor=$db->prepare("SELECT * FROM urunler WHERE urun_durum=:urun_durum ORDER BY urun_id DESC limit $limit,$sayfada");
    $urunsor->execute(array('urun_durum' => 1));
    
  <?php
     $s=0;
     while ($s < $toplam_sayfa) {
      $s++; ?>
      <?php 
      if ($s==$sayfa) {?>
            <li class="page-item">
                <a class="page-link" href="index.php?sayfa=<?php echo $s; ?>">
                    <?php echo $s; ?>
                </a>
            </li>
            <?php } else {?>
           <li class="page-item">
               <a class="page-link" href="index.php?sayfa=<?php echo $s; ?>">
                   <?php echo $s; ?>
               </a>
           </li>
           <?php } } 
           
        ?>
    

merakli
1325 gün önce

Evet atladığım yer olmuş ama ilk başta belirttiğim gibi benim istediğim sayfalama şekli
Önceki [1] [2] [3] [4] [5]...[20] Sonraki tarzı Googlede gezinirken bir makale ile karşılaştım
istediğim şeyi sağlıyor fakat ... dan sonra INF adında bir buton çıkıyor onu anlayamadım

Takılan arkadaşlar olursa vereceğim örnekle sorunlarını halledebilirler

<?php 
 $sayfada = 16; 
            $sorgu=$db->prepare("SELECT * from urunler");
            $sorgu->execute();
            $toplam_icerik=$sorgu->rowCount();
            $toplam_sayfa = ceil($toplam_icerik / $limit);
                      // eğer sayfa girilmemişse 1 varsayalım.
             $sayfa = isset($_GET['sayfa']) ? (int) $_GET['sayfa'] : 1;
                  // eğer 1'den küçük bir sayfa sayısı girildiyse 1 yapalım.
             if($sayfa < 1) $sayfa = 1; 
                  // toplam sayfa sayımızdan fazla yazılırsa en son sayfayı varsayalım.
             if($sayfa > $toplam_sayfa) $sayfa = $toplam_sayfa; 
             $limit = ($sayfa - 1) * $sayfada;

            $tumurunsor=$db->prepare("SELECT * FROM urunler WHERE urun_durum=:urun_durum ORDER BY urun_id DESC limit $limit,$sayfada");
            $tumurunsor->execute(array('urun_durum' => 1));
?>


 <?php
    if($toplam_sayfa > $limit){    
  echo '<br><br>';
  $x = 2; 
  if($sayfa > 1){
    $onceki = $sayfa-1; 
    echo '<li class="page-item"><a class="page-link" href="?sayfa='.$onceki.'">« Önceki </a></li>';   
  }    
  if($sayfa==1){ 
    echo '<li class="page-item"><a class="page-link">1</a></li>'; 
  }
  else{ 
    echo '<li class="page-item"><a class="page-link" href="?sayfa=1">1</a></li>'; 
  }
  if($sayfa-$x > 2){ 
    echo '...';  
    $i = $sayfa-$x;  
  }else {       
    $i = 2;       
  }
  
  for($i; $i<=$sayfa+$x; $i++) {
    if($i==$sayfa){ 
      echo '<li class="page-item"><a class="page-link">'.$i.'</a></li>';
    }
    else{
      echo '<li class="page-item"><a class="page-link" href="?sayfa='.$i.'">'.$i.'</a></li>'; 
    }
    if($i==$toplam_sayfa) break;  
  }
  
  if($sayfa+$x < $toplam_sayfa-1) { 
    echo '...';       
    echo '<li class="page-item"><a class="page-link" href="?sayfa='.$toplam_sayfa.'">'.$toplam_sayfa.'</a></li>'; // son sayfa yazdırılacak    
  }elseif($sayfa+$x == $toplam_sayfa-1) {       
    echo '<li class="page-item"><a class="page-link" href="?sayfa='.$toplam_sayfa.'">'.$toplam_sayfa.'</a></li>';     
  }
  
  
  if($sayfa < $toplam_sayfa){   
    $sonraki = $sayfa+1;      
    echo '<li class="page-item"><a class="page-link" href="?sayfa='.$sonraki.'"> Sonraki » </a></li>';     
  } 
} ?>