第一次写的分页类

时间:2022-10-26 16:42:08
之前看过几个分页类代码都比较长和复杂,愧于自己水平低下,没能看懂那些代码,加上发现
当要在复合条件查询并分页显示数据的时候,那就很不好用了,于是想自己写一个。
使用PHP五个月,对于类的概念和使用也才刚刚似懂非懂,这是本人第一次写的类——分页导航类,
希望各位能给点评价,特别是高手来指点指点!!

/*
_________________________________
 CLASS NAME:SHOWPAGE
_________________________________
 Copyright(c): ERLDY(稻草人)
 Author: Arvan  [E-mail:erldy@126.com QQ:103808353]
 Create date:   2004-09-27
 ________________________________
*/
 /*****
实例:
$sql = "select count(*)as count from $tbl";
$db->query($sql);
$db->next_record();
$count = $db->f(count);//记录总数

$page = new ShowPage;
  $page->PageSize = 20;
$page->Total = $count;
$page->LinkAry = array(); //使用array("id"=>$id)这样的数组传递url变量
$sql = "select * from $tbl order by sortid desc limit  ".$page->OffSet();
$db->query($sql);
$showpage = $page->ShowLink();

   
*****/
 class ShowPage {
 
var $PageSize;     //每页显示的记录数

var $Total;        //记录总数

var $LinkAry;      //Url参数数组,对于复合条件查询分页显示情况非常好用

//取得总页数
function PageCount() {
$TotalPage = ($this->Total % $this->PageSize == 0) ? floor($this->Total / $this->PageSize) :  floor($this->Total / $this->PageSize)+1;
return $TotalPage;
}
//取得当前页
function PageNum() {
$page =  (isset( $_GET['page'])!="") ? $_GET['page'] :  $page = 1; 
return $page;
}
//查询语句定位指针
function OffSet() {
if ($this->PageNum() > $this->PageCount()) {
        //$this->PageNum = $this->PageCount();
        $pagemin = max(0,$this->Total - $this->PageSize - 1);
        }else if ($this->PageNum() == 1){
        $pagemin = 0;
        }else {
        $pagemin = min($this->Total - 1,$this->PageSize * ($this->PageNum() - 1));
          }
return $pagemin . "," . $this->PageSize;
    }
//定位首页
function FristPage() {
$Frist = ($this->PageNum() <= 1) ? "首页  " : "<a href=\"?page=1".$this->Url($this->LinkAry)."\">首页</a> ";
return $Frist;
}
//定位上一页
function PrePage() {
$prepage=$this->PageNum() - 1;
$Previous = ($this->PageNum() >= 2) ? " <a href=\"?page=".$prepage.$this->Url($this->LinkAry)."\">上一页</a> " : "上一页 ";
return $Previous;
}
//定位下一页
function NextPage() {
$nextpage = $this->PageNum() + 1;
$Next = ($this->PageNum() <= $this->PageCount()-1) ? " <a href=\"?page=".$nextpage.$this->Url($this->LinkAry)."\">下一页</a> " : "下一页 ";
return $Next;
}
//定位最后一页
function LastPage() {
$Last = ($this->PageNum() >= $this->PageCount()) ? "尾页  " : " <a href=\"?page=".$this->PageCount().$this->Url($this->LinkAry)."\">尾页</a> ";
return $Last;
}
//下拉跳转页面
function JumpPage() {
$Jump = " 当前第 <b>".$this->PageNum()."</b> 页  共 <b>".$this->PageCount()."</b> 页 跳到 <select name=page onchange=\"javascript:location=this.options[this.selectedIndex].value;\">";
for ($i=1; $i<=$this->PageCount(); $i++) {
if ($i==$this->PageNum())
$Jump .= "<option value=\"?page=".$i.$this->Url($this->LinkAry)."\" selected>$i</option>";
else 
$Jump .="<option value=\"?page=".$i.$this->Url($this->LinkAry)."\">$i</option> ";
}
    $Jump .= "</select> 页   <b>[".$this->PageSize."条/页]</b>";
return $Jump;
}
//URL参数处理
function Url($ary) {
$Linkstr = "";
if (count($ary) > 0) {
foreach ($ary as $key => $val) {
$Linkstr .= "&".$key."=".$val;
}
}
return $Linkstr;
}
//生成导航条
function ShowLink() {
return $this->FristPage().$this->PrePage().$this->NextPage().$this->LastPage().$this->JumpPage();
}
 }

这个类实现了分页的一般但比较全的功能,自我感觉结构非常简单,代码也很容易看懂,并且也比较好用!!呵呵……

11 个解决方案

#1


另外祝CSDN各位朋友中秋快乐!!

#2


楼上的 “牛”

#3


up
支持楼主

#4


支持

#5


支持一下,8错,佩服

#6


个人觉得,
FristPage,PrePage,NextPage,LastPage
等方法是不是直接返回pageno会好一点,这样有便与代码的重用,
或者将该类写成抽象类,让使用该类的人去扩展用于显示的一些方法

#7


楼上说的有道理哦!!
不过,因为我是把导航的文字和链接代码组成一个个的块,最后再连接为一个字符串输出的形式,好像不好改哦。
不过有兴趣的朋友,也可以在我的基础上进行修改,不过修改后希望能一样发出来大家共享!最后给一份给我拉!!呵呵……

#8


跟我之前发过的差不多哦,哈哈,不会是抄我的吧。
开玩笑的,中秋快乐!
http://community.csdn.net/Expert/TopicView.asp?id=3338244

#9


呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……

#10


保存下来先。大家有更好的修改版也贴出来呀。

#11


呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……


好抄得好!支持!继续努力!

#1


另外祝CSDN各位朋友中秋快乐!!

#2


楼上的 “牛”

#3


up
支持楼主

#4


支持

#5


支持一下,8错,佩服

#6


个人觉得,
FristPage,PrePage,NextPage,LastPage
等方法是不是直接返回pageno会好一点,这样有便与代码的重用,
或者将该类写成抽象类,让使用该类的人去扩展用于显示的一些方法

#7


楼上说的有道理哦!!
不过,因为我是把导航的文字和链接代码组成一个个的块,最后再连接为一个字符串输出的形式,好像不好改哦。
不过有兴趣的朋友,也可以在我的基础上进行修改,不过修改后希望能一样发出来大家共享!最后给一份给我拉!!呵呵……

#8


跟我之前发过的差不多哦,哈哈,不会是抄我的吧。
开玩笑的,中秋快乐!
http://community.csdn.net/Expert/TopicView.asp?id=3338244

#9


呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……

#10


保存下来先。大家有更好的修改版也贴出来呀。

#11


呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……


好抄得好!支持!继续努力!