2009-07-26 8 views
1

Как я могу сделать так, чтобы страница, на которой я нахожусь, не будет доступна?PHP pagination

$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> 
+1

http://thedailywtf.com/Articles/Pagination-Consternation.aspx - Несмотря на всю серьезность, Pear :: Pager, возможно, стоит посмотреть. – Thorarin

ответ

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

Лучше использовать переменную '$ page', определенную ранее, вместо возможного отмены или недопустимого' $ _GET ['page'] ' – Thorarin

+0

. Вы абсолютно правы. – Kawa

1

С if внутри for,

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

Просто нужно изменить для цикла, чтобы проверить, что текущая страница.

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

Вам нужно изменить '$ i == $ page' to! = Или заменить две строки кода. – Thorarin

+0

самый быстрый пистолет на западе ... не так много;) ... Спасибо – RedBlueThing

+0

Я знаю, что эта тема старая, но мне было интересно, если бы страница поднялась до 100 101 и так далее? Как бы вы могли изменить его так: 1 2 3 ... 100 101? – blackbull77

0

@RedBlueThing вскоре должен я видел ваш пост, я получил его на работу, хотя я получил идею от другого stackoverflow question with a little modifying of the code.

<?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>"; 
?> 

Единственное, что я не мог получить, это «следующая» или «предыдущая» кнопка. Если кто-то встанет на задачу добавления этих кнопок, сделайте снимок. Другие мудрые ..... Наслаждайтесь ..... :) Это мой способ вернуть сообщество stackoverflow, чтобы помочь мне.