程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php通用分頁類代碼

php通用分頁類代碼

編輯:關於PHP編程

php通用分頁類代碼 這是一款使用方法的php分頁代碼,我們把它總結了各種分頁代碼的特別,寫出一款php通用分頁類使用方法簡單,易懂哦。

php教程通用分頁類代碼
這是一款使用方法的php分頁代碼,我們把它總結了各種分頁代碼的特別,寫出一款php通用分頁類使用方法簡單,易懂哦。
*/

 

class dividepage{//分頁類
 private $total;//要顯示的總記錄數
 private $url;//請求的url地址
 private $displaypg;//每頁顯示的記錄數,默認為每頁顯示10條記錄
 private $page;//當前頁碼
 private $lastpg;//總頁數,即最後一頁的頁碼
 private $prepg;//前一頁
 private $nextpg;//後一頁
 private $firstcount;//記錄條數開始的序號從0開始
 private $startd;//記錄條數開始的記錄號.
 private $stopd;//記錄條數結束的記錄號.

//構造函數
public function __construct($url, $total, $displaypg){
 $this->url = $url;//請求的url
 $this->total = $total;//總記錄數
 //if($displaypg == '')
 $this->displaypg = $displaypg;//每頁顯示的記錄數
 $this->initdividepage();//初始化分頁類
 //echo ','.$this->displaypg;
}

//初始化分頁類
private function initdividepage(){
 //分析url
 $parse_url = parse_url($this->url);//將url解釋為有固定鍵值對的數組
 $url_query = $parse_url['query'];//取出url中的查詢字符串
 if($url_query){//如果有查詢字符串,則刪除查詢字串中當前頁的查詢字段如:&page=$page或page=$page
  ereg('(^|&)page=([0-9]*)', $url_query, $k);
  $this->page = $k[2];//取得當前頁的值
  $url_query = ereg_replace("(^|&)page=$this->page", '', $url_query);//刪除查詢字串中當前頁的查詢字段如:&page=$page或page=$page
  $this->url = str_replace($parse_url['query'], $url_query, $this->url);//保留其他的查詢字串,
  $this->page = $this->page ? $this->page : 1;//w如果查詢字符串中沒有當前頁的值就設當前頁為1
  if($url_query){//如果有其他查詢字符串,則以&page=$page形式添加翻頁查詢字串
   $this->url .= '&page';
  }else{//如果沒有其他查詢字串,則以page=$page形式添加翻頁查詢字串
   $this->url .= 'page';
  }
 }else{//如果沒有查詢字串,則在url後添加?page=$page形式的翻頁查詢字串
  $this->page = 1;
  $this->url .= '?page';
 }
 $this->lastpg = ceil($this->total / $this->displaypg);//計算總頁數,即最後一頁的頁碼
    $this->page = min($this->lastpg, $this->page);//如果當前頁大於總頁數,則當前頁為最後一頁的頁碼
    $this->prepg = $this->page - 1;//上一頁為當前頁減一www.bKjia.c0m
    $this->nextpg = $this->page + 1;//(($this->page == $this->lastpg) ? $this->lastpg : ($this->page + 1));//下一頁為當前頁加一,如果當前頁為最後一頁,則下一頁為0
    $this->firstcount = ($this->page - 1) * $this->displaypg;//計算當前頁,記錄條數開始的記錄號,從0開始.
 $this->startd = $this->total ? ($this->firstcount + 1) : 0;//記錄開始號從1開始
 $this->stopd = min($this->firstcount + $this->displaypg, $this->total);//記錄結束號
 //echo $this->displaypg;
 //echo $this->nextpg.'+=+='.$this->lastpg;
}

public function getpageinfo(){//取得當前頁面的基本信息,如:顯示第 1-10 條記錄,共 23 條記錄。
 return '<span class="pageinfostyle">顯示第<span class="numstyle">'.$this->startd.'-'.$this->stopd.'</span>條記錄,共<span class="numstyle">'.$this->total.'</span>條記錄。</span>';
}

public function getcommonpagenav(){//取得通常的分頁導航,如:首頁 上一頁 下一頁 尾頁
 $commonnav = '';
 if($this->lastpg == 1){//如果只有一頁,則返回翻頁導航,退出,不顯示下一頁,上一頁等。。。
  return $commonnav;
  break;
 }
 $commonnav = '<a href="'.$this->url.'=1" class="compagestyle">首頁</a>';//設置首頁導航,page=1
 if($this->prepg){
  $commonnav .= '<a href="'.$this->url.'='.$this->prepg.'" class="compagestyle">上一頁</a>';
 }else{
  $commonnav .= '<a class="fcompagestyle">上一頁</a>';
 }
 if($this->nextpg <= $this->lastpg){
  $commonnav .= '<a href="'.$this->url.'='.$this->nextpg.'" class="compagestyle">下一頁</a>';
 }else{
  $commonnav .= '<a class="fcompagestyle">下一頁</a>';
 }
 $commonnav .= '<a href="'.$this->url.'='.$this->lastpg.'" class="compagestyle">尾頁</a>';//顯示尾頁鏈接
 return $commonnav;
}

//取得跳轉分頁導航,如:第n頁
public function getjumppagenav(){
 //<select name='topage' size='1' onchange='window.location="/test/page.php?page="+this.value'>
 $jumpnav = '<span class="pageinfostyle">到第<select name="topage" size="1" class="topage"  onchange='window.location="'.$this->url.'="+this.value'>'."n";
 for($i = 1; $i <= $this->lastpg; $i++){
  if($i == $this->page){//把當前頁的頁碼作為默認選項
   $jumpnav .= '<option value="'.$i.'" selected>'.$i.'</option>'."n";
  }else{
   $jumpnav .= '<option value="'.$i.'">'.$i.'</option>'."n";
  }
 }
 $jumpnav .= '</select>頁,共<span class="numstyle">'.$this->lastpg.'</span>頁</span>';
 return $jumpnav;
}

//取得所有的分頁導航
public function getallpagenav(){
 $temp =  $this->getpageinfo().$this->getcommonpagenav().$this->getjumppagenav();
 return $temp;
}

//取得當前頁需顯示的記錄,在數據庫教程中的限定范圍,如0-9
public function getlimitstr(){
 //echo $this->page;
 //echo $this->firstcount;
 
 //echo $this->dispalypg;
 $temp = $this->firstcount.','.$this->displaypg;
 //echo $temp;
 return $temp;
}

}

/*
使用實例:

*$result=mysql教程_query("select * from tb_pagetest");//從數據庫中查詢所需顯示的數據
*$total=mysql_num_rows($result);//查詢到的數據的總條數
*$pagesize = 5;//每頁顯示的記錄條數
*$url = $_server['request_uri'];//請求的uri
*
*$dividepageclass = new dividepage($url, $total, $pagesize); //創建分頁類,(類能自動初始化)
*$limitstr = $dividepageclass->getlimitstr();//取得當前頁要顯示的記錄開始序號和每頁顯示條數,如:0, 5(顯示從0開始的5條記錄)
*echo $dividepageclass->getallpagenav();//顯示所有分頁導航條,
*如:顯示第11-13條記錄,共13條記錄。首頁 上一頁 下一頁 尾頁 到*第 1 頁,共 3 頁
*$sql = 'select * from tb_pagetest limit '.$limitstr;
*$result=mysql_query($sql);//從數據庫中取得當前頁要顯示的記錄集,然後顯示就ok
*如:
*while($row=mysql_fetch_array($result))
*echo "<hr><b>".$row[title]." | ".$row[author];

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved