thinkphp简洁、美观、靠谱的分页类

废话不多说先上图预览下,即本博客的分页;

这个分页类是在thinkphp框架内置的分页类的基础上修改而来,原分页类的一些设计,在实际运用中感觉不是很方便;

1:只有一页内容时不显示分页;

2:原分页类在当前页是第一页和最后一页的时候,不显示第一页和最后一页的按钮;

3:分页数比较少时不显示首页和末页按钮;

4:包裹分页内容的父级div没有class;

针对以上问题逐一进行了修改成如下;

1:如果没有数据不显示分页,如果有一页及以上内容即显示分页;

2:默认就显示第一页和最后一页按钮,但是在当前页是第一页和最后一页的时候按钮点击无效果;

3:默认就显示首页和末页按钮;

4:为包裹分页内容的父级div添加名为page的class;

5:显示总共查出的内容条数;

示例环境:thinkphp3.2.3

分页类目录:/Thinkphp/Library/Org/Bjy/Page.class.php

分页类代码如下:

<?php

// +----------------------------------------------------------------------

// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]

// +----------------------------------------------------------------------

// | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.

// +----------------------------------------------------------------------

// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )

// +----------------------------------------------------------------------

// | Author: 麦当苗儿 <zuojiazi@vip.qq.com> <http://www.zjzit.cn>

// +----------------------------------------------------------------------

/*

 * PHP分页类

 * 修改者:白俊遥

 * 日  期:2015.5.10

 * 邮  箱:baijunyao@baijunyao.com

 * 博  客:http://www.baijunyao.com

 */

namespace OrgBjy;

 

class Page{

    public $firstRow; // 起始行数

    public $listRows; // 列表每页显示行数

    public $parameter; // 分页跳转时要带的参数

    public $totalRows; // 总行数

    public $totalPages; // 分页总页面数

    public $rollPage   = 5;// 分页栏每页显示的页数

    public $lastSuffix = true; // 最后一页是否显示总页数

 

    private $p       = 'p'; //分页参数名

    private $url     = ''; //当前链接URL

    private $nowPage = 1;

 

    // 分页显示定制

    private $config  = array(

        'header' => '<span class="rows">共 %TOTAL_ROW% 条记录</span>',

        'first'   => '首页',

        'prev'   => '上一页',

        'next'   => '下一页',

        'last'   => '末页',

        'theme'  => '%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END% %HEADER%',

    );

 

    /**

     * 架构函数

     * @param array $totalRows  总的记录数

     * @param array $listRows  每页显示记录数

     * @param array $parameter  分页跳转的参数

     */

    public function __construct($totalRows,$listRows=20,$parameter = array()) {

        C('VAR_PAGE') && $this->p = C('VAR_PAGE'); //设置分页参数名称

        /* 基础设置 */

        $this->totalRows  = $totalRows; //设置总记录数

        $this->listRows   = $listRows;  //设置每页显示行数

        $this->parameter  = empty($parameter) ? $_GET : $parameter;

        $this->nowPage    = empty($_GET[$this->p]) ? 1 : intval($_GET[$this->p]);

        $this->nowPage    = $this->nowPage>0 ? $this->nowPage : 1;

        $this->firstRow   = $this->listRows * ($this->nowPage - 1);

    }

 

    /**

     * 定制分页链接设置

     * @param string $name  设置名称

     * @param string $value 设置值

     */

    public function setConfig($name,$value) {

        if(isset($this->config[$name])) {

            $this->config[$name] = $value;

        }

    }

 

    /**

     * 生成链接URL

     * @param  integer $page 页码

     * @return string

     */

    private function url($page){

        return str_replace(urlencode('[PAGE]'),$page,$this->url);

    }

 

    /**

     * 组装分页链接

     * @return string

     */

    public function show() {

        if(0 == $this->totalRows) return '';

 

        /* 生成URL */

        $this->parameter[$this->p] = '[PAGE]';

        $this->url = U(ACTION_NAME,$this->parameter);

        /* 计算分页信息 */

        $this->totalPages = ceil($this->totalRows / $this->listRows); //总页数

        if(!empty($this->totalPages) && $this->nowPage > $this->totalPages) {

            $this->nowPage = $this->totalPages;

        }

 

        /* 计算分页零时变量 */

        $now_cool_page      = $this->rollPage/2;

        $now_cool_page_ceil = ceil($now_cool_page);

 

        //上一页

        $up_row  = $this->nowPage - 1;

        $up_page = $up_row > 0 ? '<a class="prev" href="' . $this->url($up_row) . '">' . $this->config['prev'] . '</a>' : '<a class="prev" href="javascript:;">' . $this->config['prev'] . '</a>';

 

        //下一页

        $down_row  = $this->nowPage + 1;

        $down_page = ($down_row <= $this->totalPages) ? '<a class="next" href="' . $this->url($down_row) . '">' . $this->config['next'] . '</a>' : '<a class="next" href="javascript:;">' . $this->config['next'] . '</a>';

 

        //第一页

        $the_first = '<a class="first" href="' . $this->url(1) . '">' . $this->config['first'] . '</a>';

 

        //最后一页

        $the_end = '<a class="end" href="' . $this->url($this->totalPages) . '">' . $this->config['last'] . '</a>';

 

        //数字连接

        $link_page = "";

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

            if(($this->nowPage - $now_cool_page) <= 0 ){

                $page = $i;

            }elseif(($this->nowPage + $now_cool_page - 1) >= $this->totalPages){

                $page = $this->totalPages - $this->rollPage + $i;

            }else{

                $page = $this->nowPage - $now_cool_page_ceil + $i;

            }

            if ($page>0) {

                if($page != $this->nowPage){

                    if($page <= $this->totalPages){

                        $link_page .= '<a class="num" href="' . $this->url($page) . '">' . $page . '</a>';

                    }else{

                        break;

                    }

                }else{

                    $link_page .= '<span class="current">' . $page . '</span>';

                }                

            }

 

        }

 

        //替换分页内容

        $page_str = str_replace(

            array('%HEADER%','%NOW_PAGE%','%UP_PAGE%','%DOWN_PAGE%','%FIRST%','%LINK_PAGE%','%END%','%TOTAL_ROW%','%TOTAL_PAGE%'),

            array($this->config['header'],$this->nowPage,$up_page,$down_page,$the_first,$link_page,$the_end,$this->totalRows,$this->totalPages),

            $this->config['theme']);

        return '<div class="page">'.$page_str.'</div>';

    }

}

分页类调用:

    $count=$this->where($where)->count();

    $page=new OrgBjyPage($count,$limit);

    $list=$this->where($where)->order('addtime desc')->limit($page->firstRow.','.$page->listRows)->select();

    $show=$page->show();

分页类css:

.b-page {

    background:#fff;

    box-shadow:0 1px 2px 0 #e2e2e2

}

.b-page .page {

    width:100%;

    padding:30px 15px;

    background:#fff;

    text-align:center;

    overflow:hidden

}

.b-page .page .first,.b-page .page .prev,.b-page .page .current,.b-page .page .num,.b-page .page .next,.b-page .page .end {

    padding:8px 16px;

    margin:0 5px;

    display:inline-block;

    color:#008cba;

    border:1px solid #f2f2f2;

    border-radius:5px

}

.b-page .page .first:hover,.b-page .page .prev:hover,.b-page .page .current:hover,.b-page .page .num:hover,.b-page .page .next:hover,.b-page .page .end:hover {

    text-decoration:none;

    background:#f8f5f5

}

.b-page .page .current {

    background-color:#008cba;

    color:#fff;

    border-radius:5px;

    border:1px solid #008cba

}

.b-page .page .current:hover {

    text-decoration:none;

    background:#008cba

}

分页类的使用方法和原thinkphp相同,具体参考:thinkphp手册-数据分页

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


(1)创建数据表: CREATE TABLE IF NOT EXISTS `think_form` (   `id` smallint(4) unsigned NOT NULL AUTO_INCREMENT,
组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,由于采用数组的
(1)创建模版:/App/Home/View/Form/edit.html   <FORM method=\"post\" action=\"__URL__/update\">
自定义配置文件user.php: <?php return array(    \'sex\'=>\'man\', ); config.php: <?php return array(
在一些成熟的CMS系统中,后台一般都包含一个配置中心(如织梦后台中系统设置),以方便站长在后台修改配置文件;那么这个功能是如果实现的呢?在ThinkPHP中有没有捷径可走呢?答案肯定是有的。下面大概说一下这个功能
废话不多说先上图预览下,即本博客的分页; 这个分页类是在thinkphp框架内置的分页类的基础上修改而来,原分页类的一些设计,在实际运用中感觉不是很方便;
在php中截取字符串的函数有很多,而在thinkphp中也可以直接使用php的函数,本文给大家简单的介绍thinkPHP模板中截取字符串的具体用法,希望能对各位有所帮助。
thinkphp开发图片上传,图片异步上传是目前比较方便的功能,这里我就不写css文件了,将代码写出来。
配置数据库:/app/Common/Conf/config.php 方法一: // 添加数据库配置信息 \'DB_TYPE\'   => \'mysql\',// 数据库类型
/app/Home/Controller/IndexController.class.php
(1)创建数据表: CREATE TABLE IF NOT EXISTS `think_data` (   `id` int(8) unsigned NOT NULL AUTO_INCREMENT,
(1)控制器设置:/app/Home/Controller/IndexController.class.php <?php namespace HomeController; use ThinkController;
(1)普通模式 http://localhost/index.php?m=module&a=action&var=value m参数表示模块,a操作表示操作(模块和操作的URL参数名称是可以配置的),后面的表示其他GET参数。
入库的时候用htmlspecialchars()处理含有html代码的内容 输出的时候用htmlspecialchars_decode()处理含有html代码的内容
<?php define(\'APP_NAME\',\'app\'); define(\'APP_PATH\',\'./app/\'); define(\'APP_DEBUG\',TRUE); // 开启调试模式
(1)创建控制器中定义read方法:/App/Home/Controller/FormController.class.php public function read($id=0){
一、实现不同字段相同的查询条件 $User = M(\"User\"); // 实例化User对象 $map[\'name|title\'] = \'thinkphp\';
如果你的数据完全是内部操作写入而不是通过表单的话(也就是说可以充分信任数据的安全),那么可以直接使用add方法,如:
查询表达式的使用格式: $map[\'字段名\'] = array(\'表达式\',\'查询条件\'); 表达式不分大小写,支持的查询表达式有下面几种,分别表示的含义是:
一、使用字符串作为查询条件 $User = M(\"User\"); // 实例化User对象 $User->where(\'type=1 AND status=1\')->select();