Php sayfalama
<?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 } }
?>
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>';
}
} ?>