PHP和MYSQL實(shí)現(xiàn)分頁導(dǎo)航思路詳解
預(yù)期效果

思路
通過SQL語句 SELECT * FROM table LIMIT start end 來從MySql數(shù)據(jù)庫
步驟
傳入頁碼p;
根據(jù)頁碼獲取數(shù)據(jù)php->mysql
顯示數(shù)據(jù)+分頁條
源碼
注意點(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,再考慮前面的省略號
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)航思路詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
PHP文章采集URL補(bǔ)全函數(shù)(FormatUrl)
寫此函數(shù)作用就是為了開發(fā)采集程序,采集文章的時(shí)候會(huì)經(jīng)常遇到頁面里的路徑是 相對路徑 或者 絕對根路徑 不是 絕對全路徑 就無法收集URL2012-08-08
tp5 實(shí)現(xiàn)列表數(shù)據(jù)根據(jù)狀態(tài)排序
今天小編就為大家分享一篇tp5 實(shí)現(xiàn)列表數(shù)據(jù)根據(jù)狀態(tài)排序,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
Laravel訪問出錯(cuò)提示:`Warning: require(/vendor/autoload.php): faile
這篇文章主要介紹了Laravel訪問出錯(cuò)提示:`Warning: require(/vendor/autoload.php): failed to open stream: No such file or di解決方法,涉及Laravel框架相關(guān)配置與安裝操作技巧,需要的朋友可以參考下2019-04-04
laravel使用Redis實(shí)現(xiàn)網(wǎng)站緩存讀取的方法詳解
這篇文章主要給大家介紹了關(guān)于laravel使用Redis實(shí)現(xiàn)網(wǎng)站緩存讀取的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03
PHP實(shí)現(xiàn)中國公民身份證號碼有效性驗(yàn)證示例代碼
這篇文章主要介紹了PHP實(shí)現(xiàn)中國公民身份證號碼有效性驗(yàn)證示例代碼,可以判斷身份證號碼的正確性,非常具有實(shí)用價(jià)值2017-05-05
php+ajax 實(shí)現(xiàn)輸入讀取數(shù)據(jù)庫顯示匹配信息
這篇文章主要介紹了php+ajax 實(shí)現(xiàn)輸入讀取數(shù)據(jù)庫顯示匹配信息的相關(guān)資料,需要的朋友可以參考下2015-10-10

