PHP soru pagination

3 Cevap php

Ben çıkıyorum sayfa tıklanabilir olmayacaktır ki ben ne yapardın?

$page = (isset($_GET['page']) && is_numeric($_GET['page']) ? (int) $_GET['page'] : 1);
$limit = ($page - 1) * 15;
$sql = mysql_query("SELECT * FROM log LIMIT $limit, 15");
$totalres = mysql_result(mysql_query("SELECT COUNT(id) AS tot FROM log"),0);
$totalpages = ceil($totalres / 15);

for ($i = 1; $i <= $totalpages; $i++) {
  $pagination .= "<a href=\"$_SERVER[PHP_SELF]?page=$i\">$i</a> ";
}

<p><?php echo $pagination ?></p>

3 Cevap

Sadece geçerli sayfa ne olduğunu kontrol etmek için döngü değiştirmeniz gerekir.

for ($i = 1; $i <= $totalpages; $i++) 
{
    if ($i != $page)
        $pagination .= "<a href=\"$_SERVER[PHP_SELF]?page=$i\">$i</a> ";
    else
        $pagination .= " " . $i . " ";
}

Bir if for içine ile,

if ( $i != $page) {
    //Your code.
} 
else 
{ 
    //Same page.
    $pagination .= "&nbsp;" . $page . "&nbsp;"
}

@ RedBlueThing yakında farklı bir stackoverflow question with a little modifying of the code adlı bir fikrim var, ancak ben işe aldım yazınızı gördüm sahiptir.

<?php
echo "<section>";

$link = mysqli_connect("localhost", "root", "root", "user_db");

$page = (isset($_GET['page']) && is_numeric($_GET['page']) ? (int) $_GET['page'] : 1);


$offset = 4;
$x = 5;

$limit = ($page - 1) * $offset; 

$sql = mysqli_query($link,"SELECT * FROM cfp_blogs;");
$totalres = mysqli_num_rows($sql);
$totalpages = ceil($totalres / $offset);

    $stmt = mysqli_query($link, "SELECT * FROM blogs LIMIT $limit, $offset;");
        if($stmt->num_rows > 0){
            while($obj = mysqli_fetch_object($stmt)) { 
                echo "<h1>$obj->title</h1>";
                echo "<p>$obj->content</p>";
                $stmt2 = $link->query("SELECT COUNT(id) AS Tot FROM blogs");
                if($stmt2->num_rows > 0){

                while ($obj2 = $stmt2->fetch_object()){
                        echo "<p>($obj2->Tot)</p>";
                    }
                }
                else
                echo "<p>(0)</p>";
                $stmt2->close();

            }
        }
        else {
            echo "<section class='error'><h1>There was a problem with the database.</h1></section>";
        }

    mysqli_free_result($stmt);

for ($i = $page - $x; $i < $page; $i++)
{
    if ($i >= 1) { 
        $pagination .= "<a href=\"$_SERVER[PHP_SELF]?page=$i\">$i</a> ";
    }
}

$pagination .= " " . $i . " ";

for ($i = $page + 1; $i <= $page + $x; $i++)
{
    if ($i <= $totalpages) {
        $pagination .= "<a href=\"$_SERVER[PHP_SELF]?page=$i\">$i</a> ";
    }

}

/*for ($i = 1; $i <= $totalpages; $i++) 
{
    if ($i != $page){
        $pagination .= "<a href=\"$_SERVER[PHP_SELF]?page=$i\">$i</a> ";
    }
    else{
        $pagination .= " " . $i . " ";
    }
}*/

mysqli_close($link);

echo $pagination;

echo "</section>";
?>

Ben "önceki" düğmesini bir "yeni" ya da sahip oldu alamadım tek şey. Herkes bu düğmeleri ekleyerek görev kadar ise, bir denemek. Diğer akıllı ..... Enjoy ..... :) Bu bana yardım için stackoverflow topluma geri vermek benim yoludur.