兩步快速實現PHP分頁功能,方便實用

2020-07-16 10:05:37
一般情況下我都會把資料庫讀取做一個專用類,裡面包括有對資料庫的操作,包括分頁等,這樣用起來方便。主要的程式碼有兩段:

一、讀取資料庫並轉化為分頁陣列

程式碼如下:

<?php    
    private function rs2array($sql='',$filename='',$pagesize=0){//生成二維陣列    
            $autopage=false;    
            if (!isset($sql))die("未設定語句!");    
            $str=array();    
            $result = $this->Open_Db($sql);    
            $this->recordcount=$result->recordcount;    
            if ((isset($filename)) && ($pagesize!=0)){//分頁開始    
                $autopage=true;    
                $FilesName = $filename;    
                $result->pagesize=$pagesize;    
                $page=$_GET['page'];    
                if (($page!='') && (is_numeric($page))){    
                    $epage = $page;    
                    if ($epage<1)$epage=1;    
                    if ($epage>$result->pagecount)$epage = $result->pagecount;    
                }else{    
                    $epage=1;    
                }    
                if(!$result->eof)$result->Absolutepage=$epage;    
                $whileNum=$result->pagesize;    
            }    
            if(!isset($whileNum))$whileNum=$result->recordcount;    
            for($i=1;$i<=$whileNum;$i++){    
                if($result->eof)break;    
                for($n=0;$n<=($result->fields->count-1);$n++){    
                    $str[$i-1][$result[$n]->name] = $result[$n]->value;    
                }    
                $result->movenext();    
            }    
            if($autopage==true)$this->page = $this->Paging($filename,$result->pagecount,$epage);    
            $result->close();    
            return $str;    
        }    
?>

二、供呼叫的分頁程式碼

<?php    
    static private function Paging($FilesName,$PageCount,$page){    
    $PageStr="";    
    $topname='第一頁';    
    $bottomname='最末頁';    
    $overname='上一頁';    
    $upname='下一頁';    
    $p=$FilesName.'page=';    
            if ($PageCount>1){    
                if ($page<=1){    
                    $page=1;    
                    $PageStr='當前第 '.$page.' / '.$PageCount.' 頁 ['.$topname.'] ['.$overname.'] <a href="'.$p.($page+1).'">['.$upname.']</a> <a href="'.$p.($PageCount).'">['.$bottomname.']</a>';    
                }else if($page>=$PageCount){    
                    $page=$PageCount;    
                    $PageStr='當前第 '.$page.' / '. $PageCount . ' 頁 <a href="'.$p.(1).'">['.$topname.']</a> <a href="'.$p.($page-1).'">['.$overname.']</a> ['.$upname.'] ['.$bottomname.']';    
                }else{    
                    $PageStr='當前第 ' . $page . ' / '. $PageCount . ' 頁 <a href="'.$p.(1).'">['.$topname.']</a> <a href="'.$p.($page-1).'">['.$overname.']</a> <a href="'.$p.($page+1).'">['.$upname.']</a> <a href="'.$p.($PageCount).'">['.$bottomname.']</a>';    
                }    
            }else{    
                $PageCount=1;    
                $page=1;    
                $PageStr=('當前第 ' . $page) . ' / '. $PageCount . ' 頁 ['.$topname.'] ['.$overname.'] ['.$upname.'] ['.$bottomname.']';    
            }    
            return $PageStr;    
        }    
?>

我覺得這樣在讀取資料庫的時候基本上不用擔心分頁會出什麼問題,而且如果你多個網站欄目的話,分頁都可以呼叫,非常方便。

以上程式碼不足之處還請指出,謝謝!

更過PHP相關問題請存取PHP中文網:https://www.php.cn/

以上就是兩步快速實現PHP分頁功能,方便實用的詳細內容,更多請關注TW511.COM其它相關文章!