首页建站经验 php通用分页类代码带实例教程

php通用分页类代码带实例教程

class pidepage{//分页类private $total;//要显示的总记录数private $url;//请求的url地址private $displaypg;//每页显示的记录数,默认为每页显示10条记录private $page;//…

class pidepage{//分页类

private $total;//要显示的总记录数

private $url;//请求的url地址

private $displaypg;//每页显示的记录数,默认为每页显示10条记录

private $page;//当前页码

private $lastpg;//总页数,即最后一页的页码

private $prepg;//前一页

private $nextpg;//后一页

private $firstcount;//记录条数开始的序号从0开始

private $startd;//记录条数开始的记录号.

private $stopd;//记录条数结束的记录号.

//构造函数

public function __construct($url, $total, $displaypg){

$this->url = $url;//请求的url

$this->total = $total;//总记录数

//if($displaypg == '')

$this->displaypg = $displaypg;//每页显示的记录数

$this->initpidepage();//初始化分页类

//echo ',http://www.cuoxin.com/wen/2019/11-02/'.$this->displaypg;

}

//初始化分页类

private function initpidepage(){

//分析url

$parse_url = parse_url($this->url);//将url解释为有固定键值对的数组

$url_query = $parse_url['query'];//取出url中的查询字符串
if($url_query){//如果有查询字符串,则删除查询字串中当前页的查询字段如:&page=$page或page=$page

ereg('(^|&)page=([0-9]*)', $url_query, $k);

$this->page = $k[2];//取得当前页的值

$url_query = ereg_replace("(^|&)page=$this->page", '', $url_query);//删除查询字串中当前页的查询字段如:&page=$page或page=$page

$this->url = str_replace($parse_url['query'], $url_query, $this->url);//保留其他的查询字串,

$this->page = $this->page ? $this->page : 1;//w如果查询字符串中没有当前页的值就设当前页为1

if($url_query){//如果有其他查询字符串,则以&page=$page形式添加翻页查询字串

$this->url .= '&page';

}else{//如果没有其他查询字串,则以page=$page形式添加翻页查询字串

$this->url .= 'page';

}

}else{//如果没有查询字串,则在url后添加?page=$page形式的翻页查询字串

$this->page = 1;

$this->url .= '?page';

}

$this->lastpg = ceil($this->total / $this->displaypg);//计算总页数,即最后一页的页码

$this->page = min($this->lastpg, $this->page);//如果当前页大于总页数,则当前页为最后一页的页码

$this->prepg = $this->page - 1;//上一页为当前页减一www.111cn.net

$this->nextpg = $this->page + 1;//(($this->page == $this->lastpg) ? $this->lastpg : ($this->page + 1));//下一页为当前页加一,如果当前页为最后一页,则下一页为0

$this->firstcount = ($this->page - 1) * $this->displaypg;//计算当前页,记录条数开始的记录号,从0开始.

$this->startd = $this->total ? ($this->firstcount + 1) : 0;//记录开始号从1开始

$this->stopd = min($this->firstcount + $this->displaypg, $this->total);//记录结束号

//echo $this->displaypg;

//echo $this->nextpg.'+=+=http://www.cuoxin.com/wen/2019/11-02/'.$this->lastpg;

}

public function getpageinfo(){//取得当前页面的基本信息,如:显示第 1-10 条记录,共 23 条记录。

return '显示第http://www.cuoxin.com/wen/2019/11-02/'.$this->startd.'-http://www.cuoxin.com/wen/2019/11-02/'.$this->stopd.'条记录,共http://www.cuoxin.com/wen/2019/11-02/'.$this->total.'条记录。';

}

public function getcommonpagenav(){//取得通常的分页导航,如:首页 上一页 下一页 尾页

$commonnav = '';

if($this->lastpg == 1){//如果只有一页,则返回翻页导航,退出,不显示下一页,上一页等。。。

return $commonnav;

break;

}

$commonnav = '首页';//设置首页导航,page=1

if($this->prepg){

$commonnav .= '上一页';

}else{

$commonnav .= '上一页';
}

if($this->nextpg <= $this->lastpg){

$commonnav .= '下一页';

}else{

$commonnav .= '下一页';
} //开源代码www.bcty365.com

$commonnav .= '尾页';//显示尾页链接

return $commonnav;

}

//取得跳转分页导航,如:第n页

public function getjumppagenav(){

//url.'="+this.value'>'." ";

for($i = 1; $i <= $this->lastpg; $i++){

if($i == $this->page){//把当前页的页码作为默认选项

$jumpnav .= ''." ";

}else{

$jumpnav .= ''." ";

}

}

$jumpnav .= '页,共http://www.cuoxin.com/wen/2019/11-02/'.$this->lastpg.'页';

return $jumpnav;

}

//取得所有的分页导航

public function getallpagenav(){

$temp = $this->getpageinfo().$this->getcommonpagenav().$this->getjumppagenav();////开源代码

return $temp;

}

//取得当前页需显示的记录,在数据库教程中的限定范围,如0-9

public function getlimitstr(){

//echo $this->page;

//echo $this->firstcount;

//echo $this->dispalypg;

$temp = $this->firstcount.',http://www.cuoxin.com/wen/2019/11-02/'.$this->displaypg;

//echo $temp;

return $temp;

}

}

使用实例,代码如下:

$result=mysql_query("select * from tb_pagetest");//从数据库中查询所需显示的数据

$total=mysql_num_rows($result);//查询到的数据的总条数

$pagesize = 5;//每页显示的记录条数

$url = $_server['request_uri'];//请求的uri

$pidepageclass = new pidepage($url, $total, $pagesize); //创建分页类,(类能自动初始化)

$limitstr = $pidepageclass->getlimitstr();//取得当前页要显示的记录开始序号和每页显示条数,如:0, 5(显示从0开始的5条记录)

echo $pidepageclass->getallpagenav();//显示所有分页导航条,

如:显示第11-13条记录,共13条记录。首页 上一页 下一页 尾页 到*第 1 页,共 3 页

$sql = 'select * from tb_pagetest limit '.$limitstr;

$result=mysql_query($sql);//从数据库中取得当前页要显示的记录集,然后显示就ok

如:

while($row=mysql_fetch_array($result)) //开源代码

echo "


".$row[title]." | ".$row[author];

 

本文来自网络,不代表1号站长-站长学院|资讯交流平台立场。转载请注明出处: https://www.1cn.cc/jianzhan/jingyan/17313.html
上一篇php mysql经典分页实例
下一篇 php正则去掉&lt;img&gt;标签里的height和width
admin

作者: admin

这里可以再内容模板定义一些文字和说明,也可以调用对应作者的简介!或者做一些网站的描述之类的文字或者HTML!

为您推荐

评论列表()

    联系我们

    联系我们

    0898-88888888

    在线咨询: QQ交谈

    邮箱: email@wangzhan.com

    工作时间:周一至周五,9:00-17:30,节假日休息

    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们