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="第一页">&laquo;</a></li>‘;
        }else{
            $_pageHtml .= ‘<li><a  title="第一页" href="‘.$url.‘&page=1">&laquo;</a></li>‘;
        }*/
        if($page>1){
            $_pageHtml .= <li><a  title="上一页" href=".$url.&page=.($page-1).">&laquo;</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="最后一页">&raquo;</a></li>‘;
        }else{
            $_pageHtml .= ‘<li><a  title="最后一页" href="‘.$url.‘&page=‘.$pages.‘">&raquo;</a></li>‘;
        }*/
        if($page<$_end){
            $_pageHtml .= <li><a  title="下一页" href=".$url.&page=.($page+1).">&raquo;</a></li>;
        }
        $_pageHtml .= </ul>;
        echo $_pageHtml;
    }

转载于:https://www.oschina.net/code/snippet_98890_35034

以上是关于ThinkPHP使用心得分享-分页类Page的用法的主要内容,如果未能解决你的问题,请参考以下文章

thinkphp3.2数组调用tp分页类进行分页

thinkphp自带分页类

PHP分页类及用法

PHP分页类分享

ThinkPHP 怎么结合Bootstrap进行分页

视频学习笔录---ThinkPHP---TP功能类之分页