HTML и PHP генерируют ссылки для разбивки на страницы

#php #html

#php #HTML

Вопрос:

У меня есть некоторый PHP и html-код, который загружает результаты из моей базы данных. Он показывает пять результатов на страницу. Давайте представим, что у меня 1000 страниц. Ссылки на все эти страницы исчезнут с экрана. У Google была эта проблема, но они исправили ее, отображая только текущую ссылку, а также 5 ссылок назад и 5 ссылок вперед. Я хочу сделать что-то вроде этого. Я не хочу отображать 100 ссылок на различные страницы. Представьте, что пользователь находится на странице 100. Я хочу отобразить ссылки для страницы 100, а также ссылки с 95 по 105. Как я могу это сделать? Вот мой код до сих пор:

 $page = $_GET["page"];
$pagesQuery  = mysql_query("SELECT count(id) FROM(`posts`)");
$pageNum = ceil(mysql_result($pagesQuery, 0)/5);
$start = (($page-1)*5);

$currentname = mysql_query("SELECT * FROM posts LIMIT $start, 5");  
while ($row = mysql_fetch_array($currentname)) {
        //recieve relevant data.
        $title = $row[0];
        $desc = $row[13];
        $ID = $row[6];
        $views = $row[3];
        $user = $row[7];
        //fetch the last id from accounts table.
        $fetchlast1 = mysql_query("SELECT * FROM allaccounts WHERE id=(SELECT MAX(id) FROM allaccounts)");
        $lastrow1 = mysql_fetch_row($fetchlast1);
        $lastid1 = $lastrow1[6];
        //acquire the username of postee.
        for ($i1=1; $i1 <= $lastid1; $i1  ) { 
            $currentname1 = mysql_query("SELECT * FROM allaccounts WHERE id=$user");
            while ($row1 = mysql_fetch_array($currentname1)) {
                $username1 = $row1[0];
            }
        }

        //Format Title, description and view count.
        $title2 = rtrim($title);
        $donetitle = str_replace(" ", "-", $title2);
        $url = "articles/".$ID."/".$donetitle."";

        $donetitle = strlen($title) > 40 ? substr($title,0,40)."..." : $title;
        $donedesc = '';

        if(strlen($desc) > 150) {
            $donedesc = explode( "n", wordwrap( $desc, 150));
            $donedesc1 = $donedesc[0] . '...';                          
        }else{
            $donedesc1 = $desc;                         
        }
        $finviews = number_format($views, 0, '.', ',');

        //Give relevant results
        if(stripos($title, $terms) !== false || stripos($desc, $terms) !== false || stripos($username1, $terms) !== false){
                if($row[10] == null){
                    $SRC = "img/tempsmall.jpg";
                }else{
                    $SRC ="generateThumbnailSmall.php?id=$ID"; 
                }
                echo "<div id = "feature">

                       <img src="$SRC" alt = "article thumbnail" />
                      </div>
                        <div id = "feature2">
                             <a href= "$url" id = "titletext" alt = "article title">$donetitle</a>
                             <p id="resultuser" >$username1</p>
                             <p id="resultp">$donedesc1</p>
                             <a href = "sendflag.php?title=$titleamp;url=$urlamp;id=$IDamp;userid=$user" id = "flag" alt = "flag"><img src="img/icons/flag.png"/></a><b id="resultview">$finviews views</b> 

                        </div>
                      <div id = "border"></div>";
            }                   
}

for ($j=1; $j < $pageNum; $j  ) { 
    echo "<a id ="" href="searchresults.php?search=".$terms."amp;page=".$j."">".$j."</a>";
}
  

Комментарии:

1. Используйте этот универсальный скрипт для реализации разбивки на страницы, https://github.com/rajdeeppaul/Pagination

2. Не используйте mysql_* функции, они устарели с PHP 5.5 и полностью удалены в PHP 7.0. MySQLi PDO Вместо этого используйте или. С помощью приведенного выше скрипта вы можете легко реализовать разбивку на страницы с помощью MySQLi PDO драйвера or.

Ответ №1:

Что вы хотите, так это изменить это:

 for ($j=1; $j < $pageNum; $j  ) { 
 echo "<a id ="" href="searchresults.php?search=".$terms."amp;page=".$j."">".$j."</a>";
}
  

Здесь вы перечисляете все ссылки $ j < $ pageNum, и вы хотите перечислить только 10: $ j <= 10, начиная с $ j = $currentPage или $ j = $currentPage — 5, если $ currentPage> 5