預(yù)期效果
思路
通過SQL語句 SELECT * FROM table LIMIT start end
來從MySql數(shù)據(jù)庫
步驟
傳入頁碼p;
根據(jù)頁碼獲取數(shù)據(jù)php->mysql
顯示數(shù)據(jù)+分頁條
源碼
github 鏈接
注意點
- table,input,button等控件的樣式不會繼承body,需要重新定義如下
input,label, select,option,textarea,button,fieldset,legend,table{ font-size:18px; FONT-FAMILY:verdana; }
- 在進(jìn)行查詢數(shù)據(jù)庫語言拼接的時候,LIMIT關(guān)鍵字后面要留空格,且拼接的內(nèi)容要用括弧包裹
$sql= "SELECT * FROM pages LIMIT ".(($page-1)*5).",5";
- 在顯示頁的時候,作者的邏輯比較復(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實現(xiàn)分頁導(dǎo)航思路詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對網(wǎng)站的支持!
【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。