| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1294 人关注过本帖
标题:新闻列表分页类求助
只看楼主 加入收藏
linjirongkk
Rank: 2
等 级:论坛游民
帖 子:92
专家分:20
注 册:2007-9-21
结帖率:78.95%
收藏
 问题点数:0 回复次数:3 
新闻列表分页类求助
    include("conn.php");
    $sql="select * from news_content order by news_id Desc";
    $query=$mysql-> query($sql);
    while($row=$mysql-> fetch_array($query)){
           echo $row["title"];

        }// 这是我写的一个新闻列表...要用下面的分页类来分页,那个朋友帮忙一下


      ?>
------------------------------------------------这是调用方法------------------------
<?php   
require_once("SubPages.php");   
//每页显示的条数   
  $page_size=20;   
//总条目数   
  $nums=1024;   
//每次显示的页数   
  $sub_pages=10;   
//得到当前是第几页   
  $pageCurrent=$_GET["p"];   
  //if(!$pageCurrent) $pageCurrent=1;   
      
  $subPages=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"test.php?p=",2);   
?>   

----------------------------------------------------------------------------------------------------






--------------------------------------分页类-------------------------------------------------------------
<?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" mce_href="$firstPageUrl">首页</a>] ";      
    $subPageCss1Str.="[<a href="$prewPageUrl" mce_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" mce_href="$nextPageUrl">下一页</a>] ";      
    $subPageCss1Str.="[<a href="$lastPageUrl" mce_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" mce_href="$firstPageUrl">首页</a>] ";      
    $subPageCss2Str.="[<a href="$prewPageUrl" mce_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;" mce_style="color:red;font-weight:bold;">".$s."</span>]";      
     }else{      
     $url=$this->subPage_link.$s;      
     $subPageCss2Str.="[<a href="$url" mce_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" mce_href="$nextPageUrl">下一页</a>] ";      
    $subPageCss2Str.="[<a href="$lastPageUrl" mce_href="$lastPageUrl">尾页</a>] ";      
    }else {      
    $subPageCss2Str.="[下一页] ";      
    $subPageCss2Str.="[尾页] ";      
    }      
    echo $subPageCss2Str;      
   }      
}      
?>
搜索更多相关主题的帖子: 列表 
2009-11-16 23:18
aspic
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:51
帖 子:2258
专家分:8050
注 册:2008-2-18
收藏
得分:0 
你有类也知道调用方法不知道你要别人帮你什么忙
2009-11-17 09:33
外部三电铃
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:那一年
等 级:贵宾
威 望:57
帖 子:2012
专家分:7306
注 册:2007-12-17
收藏
得分:0 
楼主要求助个啥呀

那一年,苍井空还是处女
2009-11-17 22:21
kissplay
Rank: 2
等 级:论坛游民
帖 子:15
专家分:10
注 册:2010-1-31
收藏
得分:0 
<?php
require_once("SubPages.php");

  $page_size=10;//每页显示的条数

  $pageCurrent=$_GET["p"];if(!$pageCurrent) $pageCurrent=1;//得到当前是第几页

  $nums=mysql_num_rows(mysql_query("SELECT * FROM `news_content `"));//统计总条目数

  $sub_pages=5;//每次显示的页数

/* 显示时调用
 * $page=$page_size*($pageCurrent-1);
 * ......LIMIT $page, $page_size;
*/


  

/**********************************************/

include("conn.php");
    $page=$page_size*($pageCurrent-1);
    $sql="select * from news_content order by news_id Desc LIMIT $page, $page_size;";
    $query=$mysql-> query($sql);
    while($row=$mysql-> fetch_array($query)){
           echo $row["title"];

$subPages=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"show.php?p=",2);//显示页码

?>
2010-02-02 13:41
快速回复:新闻列表分页类求助
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.030144 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved