本文實例講述了php自定義分頁類。分享給大家供大家參考,具體如下:
<?php header("Content-type:text/html;Charset=utf-8"); class SubPages{ private $each_disNums;//每頁顯示的條目數 private $nums;//總條目數 private $current_page;//當前被選中的頁 private $sub_pages;//每次顯示的頁數 private $pageNums;//總頁數 private $page_array = array();//用來構造分頁的數組 private $subPage_link;//每個分頁的鏈接 //private $subPage_type;//顯示分頁的類型 /* 當@subPage_type=1的時候為普通分頁模式 example: 共4523條記錄,每頁顯示10條,當前第1/453頁 [首頁] [上頁] [下頁] [尾頁] 當@subPage_type=2的時候為經典分頁樣式 example: 當前第1/453頁 [首頁] [上頁] 1 2 3 4 5 6 7 8 9 10 [下頁] [尾頁] */ function __construct($each_disNums,$nums,$current_page,$sub_pages,$subPage_link){ $this->each_disNums=intval($each_disNums); $this->nums=intval($nums); if(!$current_page){ $this->current_page=1; }else{ $this->current_page=intval($current_page); } $this->sub_pages=intval($sub_pages); $this->pageNums=ceil($nums/$each_disNums); $this->subPage_link=$subPage_link; // $this->show_SubPages($subPage_type); } // show_SubPages函數用在構造函數裡面。而且用來判斷顯示什麼樣子的分頁 /* function show_SubPages($subPage_type){ if($subPage_type == 1){ $this->subPageCss1(); }else if ($subPage_type == 2){ $this->subPageCss2(); } } */ //用來給建立分頁的數組初始化的函數。 function initArray(){ for($i=0;$i<$this->sub_pages;$i++){ $this->page_array[$i]=$i; } return $this->page_array; } /* construct_num_Page該函數使用來構造顯示的條目 即使:[1][2][3][4][5][6][7][8][9][10] */ function construct_num_Page(){ if($this->pageNums < $this->sub_pages){ $current_array=array(); for($i=0;$i<$this->pageNums;$i++){ $current_array[$i]=$i+1; } }else{ $current_array=$this->initArray(); if($this->current_page <= 3){ for($i=0;$i<count($current_array);$i++){ $current_array[$i]=$i+1; } }else if ($this->current_page <= $this->pageNums && $this->current_page > $this->pageNums - $this->sub_pages + 1 ){ for($i=0;$i<count($current_array);$i++){ $current_array[$i]=($this->pageNums)-($this->sub_pages)+1+$i; } }else{ for($i=0;$i<count($current_array);$i++){ $current_array[$i]=$this->current_page-2+$i; } } } return $current_array; } /* 構造普通模式的分頁 共4523條記錄,每頁顯示10條,當前第1/453頁 [首頁] [上頁] [下頁] [尾頁] */ function subPageCss1(){ $subPageCss1Str=""; $subPageCss1Str.="共".$this->nums."條記錄,"; $subPageCss1Str.="每頁顯示".$this->each_disNums."條,"; $subPageCss1Str.="當前第".$this->current_page."/".$this->pageNums."頁 "; if($this->current_page > 1){ $firstPageUrl=$this->subPage_link."1"; $prewPageUrl=$this->subPage_link.($this->current_page-1); $subPageCss1Str.="[<a href='$firstPageUrl'>首頁</a>] "; $subPageCss1Str.="[<a href='$prewPageUrl'>上一頁</a>] "; }else { $subPageCss1Str.="[首頁] "; $subPageCss1Str.="[上一頁] "; } if($this->current_page < $this->pageNums){ $lastPageUrl=$this->subPage_link.$this->pageNums; $nextPageUrl=$this->subPage_link.($this->current_page+1); $subPageCss1Str.=" [<a href='$nextPageUrl'>下一頁</a>] "; $subPageCss1Str.="[<a href='$lastPageUrl'>尾頁</a>] "; }else { $subPageCss1Str.="[下一頁] "; $subPageCss1Str.="[尾頁]"; } return $subPageCss1Str; //在此可以設置顯示的CSS樣式 } /* 構造經典模式的分頁 當前第1/453頁 [首頁] [上頁] 1 2 3 4 5 6 7 8 9 10 [下頁] [尾頁] */ function subPageCss2(){ $subPageCss2Str=""; $subPageCss2Str.="當前第".$this->current_page."/".$this->pageNums."頁 "; if($this->current_page > 1){ $firstPageUrl=$this->subPage_link."1"; $prewPageUrl=$this->subPage_link.($this->current_page-1); $subPageCss2Str.="[<a href='$firstPageUrl'>首頁</a>] "; $subPageCss2Str.="[<a href='$prewPageUrl'>上一頁</a>] "; }else { $subPageCss2Str.="[首頁] "; $subPageCss2Str.="[上一頁] "; } $a=$this->construct_num_Page(); for($i=0;$i<count($a);$i++){ $s=$a[$i]; if($s == $this->current_page ){ $subPageCss2Str.="[<span style='color:red;font-weight:bold;'>".$s."</span>]"; }else{ $url=$this->subPage_link.$s; $subPageCss2Str.="[<a href='$url'>".$s."</a>]"; } } if($this->current_page < $this->pageNums){ $lastPageUrl=$this->subPage_link.$this->pageNums; $nextPageUrl=$this->subPage_link.($this->current_page+1); $subPageCss2Str.=" [<a href='$nextPageUrl'>下一頁</a>] "; $subPageCss2Str.="[<a href='$lastPageUrl'>尾頁</a>] "; }else { $subPageCss2Str.="[下一頁] "; $subPageCss2Str.="[尾頁] "; } return $subPageCss2Str; } } //使用如下 /*include('../mysql.php'); //每頁顯示的條數 $page_size=3; //總條目數 $sql=mysql_query("select * from `stu_info`"); $nums=mysql_num_rows($sql); //每次顯示的頁數 $sub_pages=10; //得到當前是第幾頁 if(!isset($_GET["p"])){ $pageCurrent=1; }else{ $pageCurrent=$_GET["p"]; } $subPages=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"page.php?p="); $page=$subPages->subPageCss2(); echo $page;//在此可以設置CSS樣式 $ss=mysql_query("select * from `stu_info` limit ".$page_size*($pageCurrent-1).",".$page_size); while($row=mysql_fetch_array($ss)){ echo $row['stunum'].''.$row['stuname'].''.$row['clanum'].'<br>'; }*/ ?>
希望本文所述對大家PHP程序設計有所幫助。