php三种分页

<?php 
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;//显示分页的类型 
   /*
   __construct是SubPages的构造函数,用来在创建类的时候自动运行.
   @$each_disNums   每页显示的条目数
   @nums     总条目数
   @current_num     当前被选中的页
   @sub_pages       每次显示的页数
   @subPage_link    每个分页的链接
   @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,$subPage_type){ 
   $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);  
   //echo $this->pageNums."--".$this->sub_pages; 
  } 
   
   
  /*
    __destruct析构函数,当类不在使用的时候调用,该函数用来释放资源。
   */ 
  function __destruct(){ 
    unset($each_disNums); 
    unset($nums); 
    unset($current_page); 
    unset($sub_pages); 
    unset($pageNums); 
    unset($page_array); 
    unset($subPage_link); 
    unset($subPage_type); 
   } 
   
  /*
    show_SubPages函数用在构造函数里面。而且用来判断显示什么样子的分页  
   */ 
  function show_SubPages($subPage_type){ 
    if($subPage_type == 1){ 
    $this->subPageCss1(); 
    }elseif ($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; 
      } 
     }elseif ($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.="[尾页] "; 
    } 
    
    echo $subPageCss1Str; 
    
   } 
   
   
  /*
   构造经典模式的分页
   当前第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;padding:4px 5px 5px 5px;margin:0 3px 3px 2px;background:#00f;'>".$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.="尾页 "; 
    } 
    echo $subPageCss2Str; 
   } 

?>  

 

页面实现

<style>
a{border:1px solid #0099FF;padding:4px 5px 5px 5px;margin:0 3px 3px 2px;text-decoration:none;font-size:12px;color:#000;};
a:hover{background:#003366;font-weight:bold;color:#FFFFFF;}
</style>
<?php 
require_once("fenyei.php");
require_once("action/conf.php");
//每页显示的条数 
     $page_size=20; 
  $dbh = @mysql_connect($host,$user,$pwd);
  mysql_select_db($db,$dbh);
     if(!$dbh){die("error");}
     $sql = "select count(*) as nums from songinfo";
  mysql_query("set names utf8");
  $result = mysql_query($sql,$dbh);
  while($row = mysql_fetch_array($result))
  {
  $nums=$row["nums"];
  }
  //$nums=1024; 
//每次显示的页数 
  $sub_pages=10; 
//得到当前是第几页 


 $pageCurrent=isset($_GET["p"])?intval($_GET["p"]):1; //判断是否为空,为空就为1


  $sqllist = "select * from songinfo order by song_id desc limit " .($pageCurrent-1)*$page_size ."," .$page_size;
  mysql_query("set names utf8");
 
  $result = mysql_query($sqllist,$dbh);

  while($row = mysql_fetch_array($result))
  echo $row['song_name']." <br />";

  mysql_close($dbh);
 
   
  $subPages=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"fenyeiexample.php?p=",2); 
?>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值