当要在复合条件查询并分页显示数据的时候,那就很不好用了,于是想自己写一个。
使用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会好一点,这样有便与代码的重用,
或者将该类写成抽象类,让使用该类的人去扩展用于显示的一些方法
FristPage,PrePage,NextPage,LastPage
等方法是不是直接返回pageno会好一点,这样有便与代码的重用,
或者将该类写成抽象类,让使用该类的人去扩展用于显示的一些方法
#7
楼上说的有道理哦!!
不过,因为我是把导航的文字和链接代码组成一个个的块,最后再连接为一个字符串输出的形式,好像不好改哦。
不过有兴趣的朋友,也可以在我的基础上进行修改,不过修改后希望能一样发出来大家共享!最后给一份给我拉!!呵呵……
不过,因为我是把导航的文字和链接代码组成一个个的块,最后再连接为一个字符串输出的形式,好像不好改哦。
不过有兴趣的朋友,也可以在我的基础上进行修改,不过修改后希望能一样发出来大家共享!最后给一份给我拉!!呵呵……
#8
跟我之前发过的差不多哦,哈哈,不会是抄我的吧。
开玩笑的,中秋快乐!
http://community.csdn.net/Expert/TopicView.asp?id=3338244
开玩笑的,中秋快乐!
http://community.csdn.net/Expert/TopicView.asp?id=3338244
#9
呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
#10
保存下来先。大家有更好的修改版也贴出来呀。
#11
呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
好抄得好!支持!继续努力!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
好抄得好!支持!继续努力!
#1
另外祝CSDN各位朋友中秋快乐!!
#2
楼上的 “牛”
#3
up
支持楼主
支持楼主
#4
支持
#5
支持一下,8错,佩服
#6
个人觉得,
FristPage,PrePage,NextPage,LastPage
等方法是不是直接返回pageno会好一点,这样有便与代码的重用,
或者将该类写成抽象类,让使用该类的人去扩展用于显示的一些方法
FristPage,PrePage,NextPage,LastPage
等方法是不是直接返回pageno会好一点,这样有便与代码的重用,
或者将该类写成抽象类,让使用该类的人去扩展用于显示的一些方法
#7
楼上说的有道理哦!!
不过,因为我是把导航的文字和链接代码组成一个个的块,最后再连接为一个字符串输出的形式,好像不好改哦。
不过有兴趣的朋友,也可以在我的基础上进行修改,不过修改后希望能一样发出来大家共享!最后给一份给我拉!!呵呵……
不过,因为我是把导航的文字和链接代码组成一个个的块,最后再连接为一个字符串输出的形式,好像不好改哦。
不过有兴趣的朋友,也可以在我的基础上进行修改,不过修改后希望能一样发出来大家共享!最后给一份给我拉!!呵呵……
#8
跟我之前发过的差不多哦,哈哈,不会是抄我的吧。
开玩笑的,中秋快乐!
http://community.csdn.net/Expert/TopicView.asp?id=3338244
开玩笑的,中秋快乐!
http://community.csdn.net/Expert/TopicView.asp?id=3338244
#9
呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
#10
保存下来先。大家有更好的修改版也贴出来呀。
#11
呵呵……我就是看了你的之后,有感而写的!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
好抄得好!支持!继续努力!
是有相似的地方,比如实例部分。我本想把SQL语句执行部分也写进类里面,但是
我发觉结合PHPLib的db_mysql.inc来实现效果更好,所以就出现和你相似的地方了,其他
的都是我自己按照分页程序代码写成类的了。
在这里还要感谢你那张贴给我的动力哦,没看到你发的贴或许我还不会写这东西呢!呵呵……
好抄得好!支持!继续努力!