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