本文目錄一覽:
怎樣用PHP實現列表分頁功能
數據多了都不好,但是相對來說視圖要好點,因為SQL採用的聚合文件排放數據形式
建立視圖的時候同時也將相關的表都聚合到一個位置了,相對要快些
還不如用存儲過程實現分頁呢,因為存儲過程建立的同時,系統還經過編譯了
php實現分頁功能
具體代碼如下:
/**
* 獲取分頁的HTML內容
* @param integer $page 當前頁
* @param integer $pages 總頁數
* @param string $url 跳轉url地址 最後的頁數以 ‘page=x’ 追加在url後面
*
* @return string HTML內容;
*/
public static function getPageHtml($page, $pages, $url){
//最多顯示多少個頁碼
$_pageNum = 5;
//當前頁面小於1 則為1
$page = $page1?1:$page;
//當前頁大於總頁數 則為總頁數
$page = $page $pages ? $pages : $page;
//頁數小當前頁 則為當前頁
$pages = $pages $page ? $page : $pages;
//計算開始頁
$_start = $page – floor($_pageNum/2);
$_start = $_start1 ? 1 : $_start;
//計算結束頁
$_end = $page + floor($_pageNum/2);
$_end = $_end$pages? $pages : $_end;
//當前顯示的頁碼個數不夠最大頁碼數,在進行左右調整
$_curPageNum = $_end-$_start+1;
//左調整
if($_curPageNum$_pageNum $_start1){
$_start = $_start – ($_pageNum-$_curPageNum);
$_start = $_start1 ? 1 : $_start;
$_curPageNum = $_end-$_start+1;
}
//右邊調整
if($_curPageNum$_pageNum $_end$pages){
$_end = $_end + ($_pageNum-$_curPageNum);
$_end = $_end$pages? $pages : $_end;
}
$_pageHtml = ‘ul class=”pagination”‘;
/*if($_start == 1){
$_pageHtml .= ‘lia title=”第一頁”«/a/li’;
}else{
$_pageHtml .= ‘lia title=”第一頁” href=”‘.$url.’page=1″«/a/li’;
}*/
if($page1){
$_pageHtml .= ‘lia title=”上一頁” href=”‘.$url.’page=’.($page-1).'”«/a/li’;
}
for ($i = $_start; $i = $_end; $i++) {
if($i == $page){
$_pageHtml .= ‘li class=”active”a’.$i.’/a/li’;
}else{
$_pageHtml .= ‘lia href=”‘.$url.’page=’.$i.'”‘.$i.’/a/li’;
}
}
/*if($_end == $pages){
$_pageHtml .= ‘lia title=”最後一頁”»/a/li’;
}else{
$_pageHtml .= ‘lia title=”最後一頁” href=”‘.$url.’page=’.$pages.'”»/a/li’;
}*/
if($page$_end){
$_pageHtml .= ‘lia title=”下一頁” href=”‘.$url.’page=’.($page+1).'”»/a/li’;
}
$_pageHtml .= ‘/ul’;
echo $_pageHtml;
}
php分頁功能怎麼實現
php本身是沒有分頁概念的,分頁是URL傳參,然後通過mysql查詢語句到數據庫獲取數據,然後實現的分頁,url上的參數,通過PHP的$_GET都是可以獲取到的。
現在市面上的PHP框架基本都有PHP分頁類,參照文檔直接調用就好了,如果想看實現過程,可以去下載一個TP框架,然後打開裏面的分頁類查看裏面的源代碼。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/290818.html