ThinkPHP使用心得分享-分页类Page的用法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ThinkPHP使用心得分享-分页类Page的用法相关的知识,希望对你有一定的参考价值。
参考技术A Thinkphp中的Page类在ThinkPHP/Extend/Library/ORG/Util/Page.class.php中,所以使用前要引入Page类:复制代码
代码如下:
import('ORG.Util.Page');
//Page类的引入
$db
=
M('abc');//实例化数据表abc
$where
=
array(
'id'=>'2';
);//条件语句$where,例表中字段id的值为2
$count
=
$db->where($where)->count();//获取符合条件的数据总数count
$page
=
new
Page($count,
10);//实例化page类,传入数据总数和每页显示10条内容
$limit
=
$page->firstRow
.
','
.
$page->listRows;//每页的数据数和内容$limit
$result
=$db->where($where))->limit($limit)->select();//分页查询结果
$this->result
=
$result;//赋值
$this->show
=
$page->show();//获取分页的底部信息
以上代码是分页类实现的基本语句,当然喜欢使用原生sql语句的朋友也可以配合原生sql语句实现查询分页:
复制代码
代码如下:
import('ORG.Util.Page');
//Page类的引入
$db
=
M('abc');//实例化数据表abc
$where
=
array(
'id'=>'2';
);//条件语句$where,例表中字段id的值为2
$count
=
$db->where($where)->count();//获取符合条件的数据总数count
$page
=
new
Page($count,
10);//实例化page类,传入数据总数和每页显示10条内容
$Modle
=
new
Model();//实例化新数据模型
$sql
=
'select
id,name
from
abc
where
'.$where.'
limit
'.$page->firstRow.','.$page->listRows;//sql语句
$result
=
$Modle->query($sql);//执行sql语句
$this->result
=
$result
$this->show=$page->show();
当然,分布查询获取的内容也可以先对查询完的数据进行处理再赋值,比如
复制代码
代码如下:
...
$result
=$db->where($where))->limit($limit)->select();//分页查询结果
$res
=
abc($result);//abc方法(自定义方法或php函数)对结果$result进行数据排序或重组处理等
$this->result
=
$res;//赋值
PHP分页类分享
/** * 获取分页的HTML内容 * @param integer $page 当前页 * @param integer $pages 总页数 * @param string $url 跳转url地址 最后的页数以 ‘&page=x‘ 追加在url后面 * * @return string HTML内容; */ public static function getPageHtml($page, $pages, $url){ //最多显示多少个页码 $_pageNum = 5; //当前页面小于1 则为1 $page = $page<1?1:$page; //当前页大于总页数 则为总页数 $page = $page > $pages ? $pages : $page; //页数小当前页 则为当前页 $pages = $pages < $page ? $page : $pages; //计算开始页 $_start = $page - floor($_pageNum/2); $_start = $_start<1 ? 1 : $_start; //计算结束页 $_end = $page + floor($_pageNum/2); $_end = $_end>$pages? $pages : $_end; //当前显示的页码个数不够最大页码数,在进行左右调整 $_curPageNum = $_end-$_start+1; //左调整 if($_curPageNum<$_pageNum && $_start>1){ $_start = $_start - ($_pageNum-$_curPageNum); $_start = $_start<1 ? 1 : $_start; $_curPageNum = $_end-$_start+1; } //右边调整 if($_curPageNum<$_pageNum && $_end<$pages){ $_end = $_end + ($_pageNum-$_curPageNum); $_end = $_end>$pages? $pages : $_end; } $_pageHtml = ‘<ul class="pagination">‘; /*if($_start == 1){ $_pageHtml .= ‘<li><a title="第一页">«</a></li>‘; }else{ $_pageHtml .= ‘<li><a title="第一页" href="‘.$url.‘&page=1">«</a></li>‘; }*/ if($page>1){ $_pageHtml .= ‘<li><a title="上一页" href="‘.$url.‘&page=‘.($page-1).‘">«</a></li>‘; } for ($i = $_start; $i <= $_end; $i++) { if($i == $page){ $_pageHtml .= ‘<li class="active"><a>‘.$i.‘</a></li>‘; }else{ $_pageHtml .= ‘<li><a href="‘.$url.‘&page=‘.$i.‘">‘.$i.‘</a></li>‘; } } /*if($_end == $pages){ $_pageHtml .= ‘<li><a title="最后一页">»</a></li>‘; }else{ $_pageHtml .= ‘<li><a title="最后一页" href="‘.$url.‘&page=‘.$pages.‘">»</a></li>‘; }*/ if($page<$_end){ $_pageHtml .= ‘<li><a title="下一页" href="‘.$url.‘&page=‘.($page+1).‘">»</a></li>‘; } $_pageHtml .= ‘</ul>‘; echo $_pageHtml; }
转载于:https://www.oschina.net/code/snippet_98890_35034
以上是关于ThinkPHP使用心得分享-分页类Page的用法的主要内容,如果未能解决你的问题,请参考以下文章