溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP和MYSQL如何實(shí)現(xiàn)分頁導(dǎo)航

發(fā)布時(shí)間:2021-06-25 11:19:32 來源:億速云 閱讀:157 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下PHP和MYSQL如何實(shí)現(xiàn)分頁導(dǎo)航,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

 預(yù)期效果

PHP和MYSQL如何實(shí)現(xiàn)分頁導(dǎo)航

思路

通過SQL語句 SELECT * FROM table LIMIT start end 來從MySql數(shù)據(jù)庫

步驟

傳入頁碼p;

根據(jù)頁碼獲取數(shù)據(jù)php->mysql

顯示數(shù)據(jù)+分頁條

源碼

github 鏈接

注意點(diǎn)

  • table,input,button等控件的樣式不會(huì)繼承body,需要重新定義如下

input,label, select,option,textarea,button,fieldset,legend,table{
font-size:18px;
FONT-FAMILY:verdana;
}
  • 在進(jìn)行查詢數(shù)據(jù)庫語言拼接的時(shí)候,LIMIT關(guān)鍵字后面要留空格,且拼接的內(nèi)容要用括弧包裹

$sql= "SELECT * FROM pages LIMIT ".(($page-1)*5).",5";
  • 在顯示頁的時(shí)候,作者的邏輯比較復(fù)雜,可以簡化梳理

//1,主要是$total_pages > $show_page,特殊情況再另外考慮;
//2,再利用for循環(huán)顯示全部;
//3,再考慮前面的省略號(hào)
if($total_pages>$show_page){
 //考慮正常情況下,...456...下一頁 尾頁
 if($page-$page_off> 1) 
$page_banner.="...";
$start=$page-$page_off;
 //非正常情況下,12...下一頁 尾頁
 if($start== 0)
$start= 1;
$end=$page+$page_off;
 //...78 總共8頁
 if($end>$total_pages)
$end=$total_pages;
 for($i=$start;$i<=$end;$i++){
 //當(dāng)前頁顯示高亮
 if($page==$i){
$page_banner.="<span class='current'>$i</span>";
 }else{
$page_banner.="<a href='".$_SERVER['PHP_SELF']."?p=".$i."'>{$i}</a>";
 }
 }
 if($page+$page_off<$total_pages)
$page_banner.="...";
 //顯示尾頁與下一頁
 if($page<$total_pages){
$page_banner.="<a href='".$_SERVER['PHP_SELF']."?p=".($page+1)."'>下一頁></a>";
$page_banner.="<a href='".$_SERVER['PHP_SELF']."?p=".($total_pages)."'>尾頁</a>";
 }else{
$page_banner.="<span class='disable'>下一頁></span>";
$page_banner.="<span class='disable'>尾頁</span>";
 }
}

最終效果

PHP和MYSQL如何實(shí)現(xiàn)分頁導(dǎo)航 

以上是“PHP和MYSQL如何實(shí)現(xiàn)分頁導(dǎo)航”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI