閱讀28 返回首頁    go 阿裏雲 go 技術社區[雲棲]


超強 php mysql分頁類代碼

<?php
class page
{
 var $page_name="page";
 var $next_page='>';//下一頁
 var $pre_page='<';//上一頁
 var $first_page='<<首頁';//首頁
 var $last_page='尾頁>>';//尾頁
 var $pre_bar='<<';//上一分頁條
 var $next_bar='>>';//下一分頁條
 var $format_left='';
 var $format_right='';
 var $page_webmode='';

 /**
  * private
  *
  */
 var $pagebarnum=10;//控製記錄條的個數。
 var $totalpage=0;//總頁數
 var $nowindex=1;//當前頁
 var $url="";//url地址頭
 var $offset=0;
 
 /**
  * constructor構造函數
  *
  * @param array $array['total'],$array['perpage'],$array['nowindex'],$array['url'],$array['ajax']...
  */
 function page($array)
 {
  if(is_array($array)){
     if(!array_key_exists('total',$array))$this->error(__FUNCTION__,'need a param of total');
     $total=intval($array['total']);
     $perpage=(array_key_exists('perpage',$array))?intval($array['perpage']):10;
     $nowindex=(array_key_exists('nowindex',$array))?intval($array['nowindex']):'';
     $url=(array_key_exists('url',$array))?$array['url']:'';
  }else{
     $total=$array;
     $perpage=10;
     $nowindex='';
     $url='';
  }
  if((!is_int($total))||($total<0))$this->error(__FUNCTION__,$total.' is not a positive integer!');
  if((!is_int($perpage))||($perpage<=0))$this->error(__FUNCTION__,$perpage.' is not a positive integer!');
  if(!empty($array['page_name']))$this->set('page_name',$array['page_name']);//設置pagename
  $this->_set_nowindex($nowindex);//設置當前頁
  $this->_set_url($url);//設置鏈接地址
  $this->totalpage=ceil($total/$perpage);
  $this->total=$total;
  $this->offset=($this->nowindex-1)*$perpage;
 }
 /**
  * 設定類中指定變量名的值,如果改變量不屬於這個類,將throw一個exception
  *
  * @param string $var
  * @param string $value
  */
 function set($var,$value)
 {
  if(in_array($var,get_object_vars($this)))
     $this->$var=$value;
  else {
   $this->error(__FUNCTION__,$var." does not belong to PB_Page!");
  }
 
 }
 /**
  * 獲取顯示"下一頁"的代碼
  *
  * @param string $style
  * @return string
  */
 function next_page($style='',$nowindex_style='')
 {
  if($this->nowindex<$this->totalpage){
   return $this->_get_link($this->_get_url($this->nowindex+1),$this->next_page,$style);
  }
  return '<span >'.$this->next_page.'</span>';
 }
 
 /**
  * 獲取顯示“上一頁”的代碼
  *
  * @param string $style
  * @return string
  */
 function pre_page($style='',$nowindex_style='')
 {
  if($this->nowindex>1){
   return $this->_get_link($this->_get_url($this->nowindex-1),$this->pre_page,$style);
  }
  return '<span >'.$this->pre_page.'</span>';
 }
 
 /**
  * 獲取顯示“首頁”的代碼
  *
  * @return string
  */
 function first_page($style='',$nowindex_style='')
 {
  if($this->nowindex==1){
      return '<span >'.$this->first_page.'</span>';
  }
  return $this->_get_link($this->_get_url(1),$this->first_page,$style);
 }
 
 /**
  * 獲取顯示“尾頁”的代碼
  *
  * @return string
  */
 function last_page($style='',$nowindex_style='')
 {
  if($this->nowindex==$this->totalpage){
      return '<span >'.$this->last_page.'</span>';
  }
  return $this->_get_link($this->_get_url($this->totalpage),$this->last_page,$style);
 }
 
 function nowbar($style='',$nowindex_style='')
 {
  $plus=ceil($this->pagebarnum/2);
  if($this->pagebarnum-$plus+$this->nowindex>$this->totalpage)$plus=($this->pagebarnum-$this->totalpage+$this->nowindex);
  $begin=$this->nowindex-$plus+1;
  $begin=($begin>=1)?$begin:1;
  $return='';
  for($i=$begin;$i<$begin+$this->pagebarnum;$i++)
  {
   if($i<=$this->totalpage){
    if($i!=$this->nowindex)
        $return.=$this->_get_text($this->_get_link($this->_get_url($i),$i,$style));
    else
        $return.=$this->_get_text('<span >'.$i.'</span>');
   }else{
    break;
   }
   $return.="/n";
  }
  unset($begin);
  return $return;
 }
 /**
  * 獲取顯示跳轉按鈕的代碼
  *
  * @return string
  */
 function select()
 {
  $return='<select name="PB_Page_Select" onchange="self.location.href=/''.$this->url.'/'+this.options[this.selectedIndex].value ">';
  for($i=1;$i<=$this->totalpage;$i++)
  {
   if($i==$this->nowindex){
    $return.='<option value="'.$i.'" selected>'.$i.'</option>';
   }else{
    $return.='<option value="'.$i.'">'.$i.'</option>';
   }
  }
  unset($i);
  $return.='</select>';
  return $return;
 }
 
 /**
  * 獲取mysql 語句中limit需要的值
  *
  * @return string
  */
 function offset()
 {
  return $this->offset;
 }
 
 /**
  * 控製分頁顯示風格(你可以增加相應的風格)
  *
  * @param int $mode
  * @return string
  */
 function show($mode=1,$style='',$nowindex_style='')
 {
  switch ($mode)
  {
   case '1':
    $this->next_page='下一頁';
    $this->pre_page='上一頁';
 $this->first_page='首頁';
    $this->last_page='尾頁';
    return $this->first_page($style,$nowindex_style)." ".$this->pre_page($style,$nowindex_style)." ".$this->next_page($style,$nowindex_style)." ".$this->last_page($style,$nowindex_style).' (當前第<span >'.$this->nowindex.'</span>頁 共<span >'.$this->totalpage.'</span>頁 <span >'.$this->total.'</span>條記錄)';
    break;
   case '2':
    $this->next_page='下一頁';
    $this->pre_page='上一頁';
    $this->first_page='首頁';
    $this->last_page='尾頁';
    return $this->first_page($style,$nowindex_style)." ".$this->pre_page($style,$nowindex_style)." ".$this->next_page($style,$nowindex_style)." ".$this->last_page($style,$nowindex_style).' 第'.$this->select().'頁 (當前第<span >'.$this->nowindex.'</span>頁 共<span >'.$this->totalpage.'</span>頁 <span >'.$this->total.'</span>條記錄)';
    break;
   case '3':
    $this->next_page='下一頁';
    $this->pre_page='上一頁';
    $this->first_page='首頁';
    $this->last_page='尾頁';
    return $this->pre_page($style,$nowindex_style)." ".$this->nowbar($style,$nowindex_style)." ".$this->next_page($style,$nowindex_style).' (當前第<span >'.$this->nowindex.'</span>頁 共<span >'.$this->totalpage.'</span>頁 <span >'.$this->total.'</span>條記錄)';
    break;
   case '4':
    $this->next_page='下一頁';
    $this->pre_page='上一頁';
    return $this->pre_page($style,$nowindex_style)." ".$this->nowbar($style,$nowindex_style)." ".$this->next_page($style,$nowindex_style).' 第'.$this->select().'頁 (當前第<span >'.$this->nowindex.'</span>頁 共<span >'.$this->totalpage.'</span>頁 <span >'.$this->total.'</span>條記錄)';
    break;
   case '5':
   $this->next_page='>';
  $this->pre_page='<';
   $this->first_page='<<';
  $this->last_page='>>';
    return $this->first_page($style,$nowindex_style)." ".$this->pre_page($style,$nowindex_style)." ".$this->nowbar($style,$nowindex_style)." ".$this->next_page($style,$nowindex_style)." ".$this->last_page($style,$nowindex_style).' (當前第<span >'.$this->nowindex.'</span>頁 共<span >'.$this->totalpage.'</span>頁 <span >'.$this->total.'</span>條記錄)';
    break;
    
      
   case '6':
       $pagehtml="<div>"; 
       if($this->nowindex>1)
       {
           $pagehtml.="<span class=/"pagenum-l/"><a href=/"{$this->_get_url($this->nowindex-1)}/"><img src=/"images/page_up.gif/" /></a></span>";
        }
        else
        {
          $pagehtml.="<span class=/"pagenum-l/"><img src=/"images/page_up.gif/" /></span>";
        }
       $pagehtml.="<span class=/"pagenum-c/">";
       $pagehtml.="<table><tr>";
        

       $plus=ceil($this->pagebarnum/2);
        if($this->pagebarnum-$plus+$this->nowindex>$this->totalpage)$plus=($this->pagebarnum-$this->totalpage+$this->nowindex);
        $begin=$this->nowindex-$plus+1;
        $begin=($begin>=1)?$begin:1;
  for($i=$begin;$i<$begin+$this->pagebarnum;$i++)
  {
   if($i<=$this->totalpage){
    if($i!=$this->nowindex)
        $pagehtml.="<td>&nbsp;<a href=/"{$this->_get_url($i)}/">{$i}</a>&nbsp;</td>";
    else
        $pagehtml.="<td>&nbsp;{$i}&nbsp;</td>";
   }else{
    break;
   }
   $pagehtml.="/n";
  }
  unset($begin);
       
       
       
       $pagehtml.="</tr></table>";
       $pagehtml.="</span>"; 
       
     
  if($this->nowindex<$this->totalpage)
  {
    $pagehtml.="<span class=/"pagenum-r/"><a href=/"{$this->_get_url($this->nowindex+1)}/"><img src=/"images/page_down.gif/" /></a></span>";
  }
  else
  {
   $pagehtml.="<span class=/"pagenum-r/"><img src=/"images/page_down.gif/" /></span>";
  }
  $pagehtml.="</div>";
  return $pagehtml;      
   
    break;
      
      
  }
 }
/*----------------private function (私有方法)-----------------------------------------------------------*/
 /**
  * 設置url頭地址
  * @param: String $url
  * @return boolean
  */
 function _set_url($url="")
 {
 if($this->page_webmode!="php"&&$url!=""){
 $this->url=$url;
 }
 else{
  if(!empty($url)){
      //手動設置
   $this->url=$url.((stristr($url,'?'))?'&':'?').$this->page_name."=";
  }else{
      //自動獲取
   if(empty($_SERVER['QUERY_STRING'])){
       //不存在QUERY_STRING時
    $this->url=$_SERVER['REQUEST_URI']."?".$this->page_name."=";
   }else{
       //
    if(stristr($_SERVER['QUERY_STRING'],$this->page_name.'=')){
        //地址存在頁麵參數
     $this->url=str_replace($this->page_name.'='.$this->nowindex,'',$_SERVER['REQUEST_URI']);
     $last=$this->url[strlen($this->url)-1];
     if($last=='?'||$last=='&'){
         $this->url.=$this->page_name."=";
     }else{
         $this->url.='&'.$this->page_name."=";
     }
    }else{
        //
     $this->url=$_SERVER['REQUEST_URI'].'&'.$this->page_name.'=';
    }//end if   
   }//end if
  }//end if
 }
}
 
 /**
  * 設置當前頁麵
  *
  */
 function _set_nowindex($nowindex)
 {
  if(empty($nowindex)){
   //係統獲取
  
   if(isset($_GET[$this->page_name])){
    $this->nowindex=intval($_GET[$this->page_name]);
   }
  }else{
      //手動設置
   $this->nowindex=intval($nowindex);
  }
 }
 
 /**
  * 為指定的頁麵返回地址值
  *
  * @param int $pageno
  * @return string $url
  */
 function _get_url($pageno=1)
 {
 if($this->page_webmode=="php"||$this->page_webmode==""){
  return $this->url.$pageno;
  }
 else{
  return $this->url.(($pageno==1)?"":"_".$pageno).".".$this->page_webmode;
  }
 }
 
 /**
  * 獲取分頁顯示文字,比如說默認情況下_get_text('<a href="">1</a>')將返回[<a href="">1</a>]
  *
  * @param String $str
  * @return string $url
  */
 function _get_text($str)
 {
  return $this->format_left.$str.$this->format_right;
 }
 
 /**
   * 獲取鏈接地址
 */
 function _get_link($url,$text,$style=''){
  $style=(empty($style))?'':'';
   return '<a '.$style.' href="'.$url.'">'.$text.'</a>';
 }
 /**
   * 出錯處理方式
 */
 function error($function,$errormsg)
 {
     die('Error in file <b>'.__FILE__.'</b> ,Function <b>'.$function.'()</b> :'.$errormsg);
 }
}
?>

 

 

調用:

 

 

<?
   include_once("lib/my_page_class.php");
   $page=new page(array('total'=>$total,'perpage'=>$pagesize));
  $pagehtml=$page->show(6,"page","curr");
  echo $pagehtml;
  ?>

 

 

 

 

 

 

 

最後更新:2017-04-02 00:06:46

  上一篇:go 非常有用的一些sql server 2005元數據函數
  下一篇:go 一起CUDA吧