
前几篇(上传,缩略图,验证码,自动验证表单)文章介绍的功能实现都是基于ThinkPHP框架封装好的类进行实现的,所以这次自己写一个分页类在框架中使用。
首先在根目录建一个Tools文件夹,在Tools文件夹下建Page.class.PHP类文件,这样以后自定义的工具类都可放在Tools文件夹下。
此类封装有以下函数:获取请求地址,开始页,从哪一条显示,结束页 从哪一条结束,页码列表(首页超链接,上一页,页码数字列表超链接,下一页,尾页,跳转),对于分页足够使用!
下面是Page.class.PHP代码
class Page {private $total; //数据表中总记录数
private $listRows; //每页显示行数
private $limit;
private $uri; //当前链接URL
private $pageNum; //页数
private $config=array('header'=>"个记录","prev"=>"上一页","next"=>"下一页","first"=>"首 页","last"=>"尾 页");
private $ListNum=8; //限制页码列表数目
/*
$total 总记录数$ListRows 每页显示行数*/
public function __construct($total,$ListRows=10,$pa=""){
$this->total=$total; //数据表中总记录数
$this->ListRows=$ListRows; //设置每页显示行数
$this->uri=$this->getUri($pa); //请求地址
$this->page=!empty($_GET["page"]) ? $_GET["page"] : 1; //当前页
$this->pageNum=ceil($this->total/$this->ListRows); //总页数
$this->limit=$this->setlimit(); //限制每页长度
}
private function setlimit(){
return "limit ".($this->page-1)*$this->ListRows.",{$this->ListRows}";
}
//请求地址
private function getUri($pa){
$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"],'?')?'':"?").$pa;
$parse=parse_url($url);
if(isset($parse["<a href="https://m.jb51.cc/tag/query/" target="_blank" >query</a>"])){ parse_str($parse['<a href="https://m.jb51.cc/tag/query/" target="_blank" >query</a>'],$p<a href="https://www.jb51.cc/tag/ara/" target="_blank" >ara</a>ms); unset($p<a href="https://www.jb51.cc/tag/ara/" target="_blank" >ara</a>ms["page"]); $url=$parse['path'].'?'.<a href="https://m.jb51.cc/tag/http/" target="_blank" >http</a>_build_<a href="https://m.jb51.cc/tag/query/" target="_blank" >query</a>($p<a href="https://www.jb51.cc/tag/ara/" target="_blank" >ara</a>ms);}return $url;}
function __get($args){
if($args=="limit")
return $this->limit;
else
return null;
}
//开始页,从哪一条显示
private function start(){
if($this->total==0)
return 0;
else
return ($this->page-1)*$this->ListRows+1;
}
//从哪一条结束
private function end(){
return min($this->page*$this->ListRows,$this->total);
}
//首页超链接
private function first(){
$HTML = "";
if($this->page==1)
$HTML.='';
else
$HTML.="uri}&page=1'>{$this->config["first"]}";
return $<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>;}
//上一页
private function prev(){
$HTML = "";
if($this->page==1)
$HTML.='';
else
$HTML.="uri}&page=".($this->page-1)."'>{$this->config["prev"]}";
return $<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>;}
//页码数字列表超链接
private function Pagelist(){
$@R_419_6862@Page="";
$inum=floor($this-><a href="https://m.jb51.cc/tag/List/" target="_blank" >List</a>Num/2);for($i=$inum; $i>=1; $i--){ $page=$this->page-$i; if($page<1) continue; $linkPage.="<a href='{$this->uri}&page={$page}'>{$page}</a>";}$linkPage.="{$this->page}";for($i=1; $i<=$inum; $i++){ $page=$this->page+$i; if($page<=$this->pageNum) $@R_<a href="https://www.jb51.cc/tag/419/" target="_blank" >419</a>_6862@Page.="@L_<a href="https://www.jb51.cc/tag/419/" target="_blank" >419</a>_2@"; else break;}return $@R_<a href="https://www.jb51.cc/tag/419/" target="_blank" >419</a>_6862@Page;}
//下一页
private function next(){
$HTML = "";
if($this->page==$this->pageNum)
$HTML.='';
else
$HTML.="uri}&page=".($this->page+1)."'>{$this->config["next"]}";
return $<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>;}
//尾页
private function last(){
$HTML = "";
if($this->page==$this->pageNum)
$HTML.='';
else
$HTML.="uri}&page=".($this->pageNum)."'>{$this->config["last"]}";
return $<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>;}
//跳转
private function goPage(){
return '<input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'&page=\'+page+\'\'}" value="'.$this->page.'" ><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.prevIoUsSibling.value;location=\''.$this->uri.'&page=\'+page+\'\'">';
}
//页码列表
function fpage($display=array(0,1,2,3,4,5,6,7,8)){
$HTML[0]="共有{$this->total}{$this->config["header"]}";
$HTML[1]="每页显示".($this->end()-$this->start()+1)."条,本页{$this->start()}-{$this->end()}条";
$HTML[2]="{$this->page}/{$this->pageNum}页";
$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[3]=$this->f<a href="https://www.jb51.cc/tag/irs/" target="_blank" >irs</a>t();$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[4]=$this->prev();$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[5]=$this-><a href="https://www.jb51.cc/tag/Pagelist/" target="_blank" >Pagelist</a>();$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[6]=$this->next();$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[7]=$this->last();$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[8]=$this->goPage();$fpage='';foreach($<a href="https://www.jb51.cc/tag/dis/" target="_blank" >dis</a>play as $index){ $fpage.=$<a href="https://m.jb51.cc/tag/HTML/" target="_blank" >HTML</a>[$index];}return $fpage;}
}
控制器代码:
//实现分页效果$goods = D('goods');
//① 获得数据的总记录条数
$total = $goods -> count(); //select count(*) from sw_goods;
$per = 7; //每页显示7条记录
//②实例化分页类
$page_obj = new \Tools\Page($total,$per);
//③自定义SQL语句,获取每页信息
$sql = "select * from swgoods order by goodsID desc ".$page_obj->limit;
$info = $goods->query($sql);
//④获取页码列表
$Pagelist = $page_obj->fpage(array(3,8));
//分配
$this->assign('Pagelist',$Pagelist);
$this->assign('info',$info);
$this->display();
}
前台显示代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持内存溢出。
总结以上是内存溢出为你收集整理的ThinkPHP实现分页功能全部内容,希望文章能够帮你解决ThinkPHP实现分页功能所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)