PHP和MYSQL實現(xiàn)分頁導航思路詳解
預期效果

思路
通過SQL語句 SELECT * FROM table LIMIT start end 來從MySql數(shù)據(jù)庫
步驟
傳入頁碼p;
根據(jù)頁碼獲取數(shù)據(jù)php->mysql
顯示數(shù)據(jù)+分頁條
源碼
注意點
- table,input,button等控件的樣式不會繼承body,需要重新定義如下
input,label, select,option,textarea,button,fieldset,legend,table{
font-size:18px;
FONT-FAMILY:verdana;
}
- 在進行查詢數(shù)據(jù)庫語言拼接的時候,LIMIT關鍵字后面要留空格,且拼接的內容要用括弧包裹
$sql= "SELECT * FROM pages LIMIT ".(($page-1)*5).",5";
- 在顯示頁的時候,作者的邏輯比較復雜,可以簡化梳理
//1,主要是$total_pages > $show_page,特殊情況再另外考慮;
//2,再利用for循環(huán)顯示全部;
//3,再考慮前面的省略號
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++){
//當前頁顯示高亮
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實現(xiàn)分頁導航思路詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
PHP設計模式之解釋器(Interpreter)模式入門與應用詳解
這篇文章主要介紹了PHP設計模式之解釋器(Interpreter)模式,結合實例形式詳細分析了PHP解釋器模式的概念、原理、基本應用與相關操作注意事項,需要的朋友可以參考下2019-12-12
YII Framework框架教程之使用YIIC快速創(chuàng)建YII應用詳解
這篇文章主要介紹了YII Framework框架教程之使用YIIC快速創(chuàng)建YII應用的方法,詳細分析說明了YII Framework框架使用YIIC命令行創(chuàng)建應用的相關技巧與注意事項,需要的朋友可以參考下2016-03-03
ThinkPHP5集成JS-SDK實現(xiàn)微信自定義分享功能
這篇文章主要介紹了ThinkPHP5集成JS-SDK實現(xiàn)微信自定義分享功能的相關資料,需要的朋友可以參考下2023-03-03
護衛(wèi)神php套件 php版本升級方法(php5.5.24)
這篇文章主要介紹了護衛(wèi)神php套件 php版本升級方法(php5.5.24),需要的朋友可以參考下2015-05-05

