一个浅显易懂的分页类

<?php
class page{
   类功能:分页
  创建时间:2005-03-12
  作者:多菜鸟
  EMAIL:kingerq AT msn.com
  来源:http://blog.csdn.net/kingerq
 
  实例:
  //省略一些连接信息及mysql类库等包含文件
  $sql = "select count(*) from t_publiccode";
  $db->query($sql);
  $db->next_record();
  $recordcount = $db->f(0);//记录总数
 
  $p = new page($recordcount, 20, 15);//(总记录数,每页记录数,每面页码个数)

  $p->ar = array("&laquo;首页", "&#8249;前页", "后页&#8250;", "末页&raquo;");//可以设置成图片HTML代码
  $trunpage = $p->show_page();//得到分页信息
 
  $sql = "select * from t_publiccode".$p->limit();
 
  //echo $trunpage."<br>".$sql;
  $db->query($sql);
  //...
 
  类似效果:
  共[52600]条记录/共[2630]页 <<首页 <前页 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 后页> 末页>>
  */

 var $pagecount;         //总页数
 
 var $limit = "";        //分页时用到的limit参数
 
 var $pagearg = "page";  //分页参数名称
 
 var $pagesize = 20;     //每页显示记录数
 
 var $recordcount;       //总记录数
 
 var $pagenum;           //当前页码
 
 var $argstr = "";       //GET参数字符串
 
 var $perpage = 5;       //每次显示页码个数
 
 var $ar = array("[&laquo;]", "[&#8249;]", "[&#8250;]", "[&raquo;]");
 
 /*
  * 功能:构造函数
  * 参数 $recordcount 为记录总数
  * 参数 $pagesize 为每页显示记录数,默认为20
  * 参数 $perpage 为每次显示页码个数,默认为5
  */
 function page($recordcount, $pagesize = 20, $perpage = 5){
  
   $this->pagesize = $pagesize;
  
   $this->recordcount = $recordcount;
  
   $this->perpage = $perpage;
  
   $this->pagecount = ceil($recordcount/$pagesize);//总页数
  
   $this->pagenum = $this->currentpage();//当前页码
  
   $this->argstr = $this->newarg();//GET参数字符串
  
   $this->limit = " LIMIT ".($this->pagenum-1)*$pagesize.",".$pagesize;//分页时用到的limit参数
 }
 
 /*
  * 功能:取得当前页码函数
  */
 function currentpage(){
  if(isset($_GET[$this->pagearg])){
   if($_GET[$this->pagearg] <= 0) {
     $page = 1;
   }else if($_GET[$this->pagearg] > $this->pagecount){
     $page = $this->pagecount;
   }else{
     $page = $_GET[$this->pagearg];
   }
  }else {
   $page = 1;
  }
  return $page;
 }
 
 /*
  * 功能:重新整理GET参数
  */
 function newarg(){
  $str = "";
  $urlar = $_GET;
  unset($urlar[$this->pagearg]);
  if($urlar){
   foreach($urlar as $key=>$val){
    if($str == "") {
   $str = "?$key=$val";
 }else {
   $str .= "&$key=$val";
 }
   }
   $str .= "&$this->pagearg=";
  }else{
   $str = "?$this->pagearg=";
  }
  return $str;
 }
 
 /*
  * 功能:返回MYSQL语句的limit部分代码
  */
 function limit(){
  return $this->limit;
 }
 /*
  * 功能:分页字符输出函数
  */
 function show_page(){
  $trunpage = "&nbsp;共[".$this->recordcount."]条记录/共[".$this->pagecount."]页&nbsp;";
  $page = $this->pagenum;
 
  //向前翻
  if($page == 1){
   $trunpage .= $this->ar[0]."&nbsp;".$this->ar[1]."&nbsp;";
  }else {
   $trunpage .= '<a href="'.$this->argstr.'1">'.$this->ar[0].'</a>&nbsp;<a href="'.$this->argstr.($page-1).'">'.$this->ar[1].'</a>&nbsp;';
  }
 
  //中间数字翻页
  $numpage = 1;
  while($page - $this->perpage * $numpage > 0) $numpage++;
  $startpage = ($numpage - 1) * $this->perpage;
  $endpage = $this->pagecount < $numpage * $this->perpage ? $this->pagecount : $numpage * $this->perpage;
  for($i = $startpage + 1; $i <= $endpage; $i++){
    $trunpage .= $i != $page ? "<a href=/"".$this->argstr.$i."/">$i</a>&nbsp;" : "<strong>".$i."</strong>&nbsp;";
  }
 
  //向后翻
  if($page == $this->pagecount || $this->pagecount == 0){
   $trunpage .= $this->ar[2]."&nbsp;".$this->ar[3]."&nbsp;";
  }else {
   $trunpage .= '<a href="'.$this->argstr.($page+1).'">'.$this->ar[2].'</a>&nbsp;<a href="'.$this->argstr.$this->pagecount.'">'.$this->ar[3].'</a>&nbsp;';
  }
 
  //跳转
  $select = "<select οnchange='location.href=this.options[this.selectedIndex].value'>/n";
  for($i = 1; $i <= $this->pagecount; $i++){
   $select .= "<option value=/"".$this->argstr.$i."/">$i</option>/n";
  }
  $select .= "</select>";
  return $trunpage.$select;
 }
}
?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值