听说TP自带的分页类不是那么强大,也不是那么美观。

TP的论坛上也有很多大神分享过些很漂亮的自定义分页类,今天学习的是这个东东。

首先,先来个自定义分页类的内容。
Page.class.php

<?php
//命名空间
namespace Component;

class Page {
    private $total; //数据表中总记录数
    private $listRows; //每页显示行数
    private $limit;
    private $uri;
    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["query"])) {
            parse_str($parse['query'], $params);
            unset($params["page"]);
            $url = $parse['path'] . '?' . http_build_query($params);

        }

        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 .= "&nbsp;&nbsp;<a href='{$this->uri}&page=1'>{$this->config["first"]}</a>&nbsp;&nbsp;";
        }

        return $html;
    }

    private function prev() {
        $html = "";
        if ($this->page == 1) {
            $html .= '';
        } else {
            $html .= "&nbsp;&nbsp;<a href='{$this->uri}&page=" . ($this->page - 1) . "'>{$this->config["prev"]}</a>&nbsp;&nbsp;";
        }

        return $html;
    }

    private function pageList() {
        $linkPage = "";

        $inum = floor($this->listNum / 2);

        for ($i = $inum; $i >= 1; $i--) {
            $page = $this->page - $i;

            if ($page < 1) {
                continue;
            }

            $linkPage .= "&nbsp;<a href='{$this->uri}&page={$page}'>{$page}</a>&nbsp;";

        }

        $linkPage .= "&nbsp;{$this->page}&nbsp;";

        for ($i = 1; $i <= $inum; $i++) {
            $page = $this->page + $i;
            if ($page <= $this->pageNum) {
                $linkPage .= "&nbsp;<a href='{$this->uri}&page={$page}'>{$page}</a>&nbsp;";
            } else {
                break;
            }

        }

        return $linkPage;
    }

    private function next() {
        $html = "";
        if ($this->page == $this->pageNum) {
            $html .= '';
        } else {
            $html .= "&nbsp;&nbsp;<a href='{$this->uri}&page=" . ($this->page + 1) . "'>{$this->config["next"]}</a>&nbsp;&nbsp;";
        }

        return $html;
    }

    private function last() {
        $html = "";
        if ($this->page == $this->pageNum) {
            $html .= '';
        } else {
            $html .= "&nbsp;&nbsp;<a href='{$this->uri}&page=" . ($this->pageNum) . "'>{$this->config["last"]}</a>&nbsp;&nbsp;";
        }

        return $html;
    }

    private function goPage() {
        return '&nbsp;&nbsp;<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 . '" style="width:25px"><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>' . $this->pageNum . ')?' . $this->pageNum . ':this.previousSibling.value;location=\'' . $this->uri . '&page=\'+page+\'\'">&nbsp;&nbsp;';
    }
    function fpage($display = array(0, 1, 2, 3, 4, 5, 6, 7, 8)) {
        $html[0] = "&nbsp;&nbsp;共有<b>{$this->total}</b>{$this->config["header"]}&nbsp;&nbsp;";
        $html[1] = "&nbsp;&nbsp;每页显示<b>" . ($this->end() - $this->start() + 1) . "</b>条,本页<b>{$this->start()}-{$this->end()}</b>条&nbsp;&nbsp;";
        $html[2] = "&nbsp;&nbsp;<b>{$this->page}/{$this->pageNum}</b>页&nbsp;&nbsp;";

        $html[3] = $this->first();
        $html[4] = $this->prev();
        $html[5] = $this->pageList();
        $html[6] = $this->next();
        $html[7] = $this->last();
        $html[8] = $this->goPage();
        $fpage = '';
        foreach ($display as $index) {
            $fpage .= $html[$index];
        }

        return $fpage;

    }

}
?>

这个自定义分页类,我在的命名空间是Component目录下面,自己也可以定义其他目录,不过定义其他的目录后这个自定义控件名称也要跟着变动,在分页控制器里面,实例化这个命名空间的名称也要跟着更改。

另外,这个自定义分页类里面,需要传入$total(数据总记录条数)和$listRows(每页显示数)两个参数。

在需要分页的控制器中代码如下:
//商品显示,分页显示数据

public function showlist() {
    $goods = M('Goods'); //实例化数据库模型
    //1,获取数据信息条数
    $total = $goods->count();
    $listRows = 8; //每页显示的条数
    //2,实例化自定义控件里面的分页类
    $page = new \Component\Page($total, $listRows);
    //3,获取页数信息,执行原生SQL,根据MYSQL条件查询
    $sql = "select * from sw_goods " . $page->limit;
    $info = $goods->query($sql);
    //4,获得分页列表
    $pagelist = $page->fpage(); //fpage()是自定义类里面的方法
    $this->assign('info', $info);    //数据显示
    $this->assign('pagelist', $pagelist);    //分页显示
    $this->display();
}

上面sw_goods是数据表名称,$page->limit,$page是TP的一个方法,limit是自定义类中的一个参数。

另外我也不太明白为什么要原生SQL语句,用TP的方法我至少还没找到如何处理,另外注意,在原生SQL后面有个空格,如果没有空格的话,SQL就会执行成

select * from sw_goodsLimit 0, 8

表名和Limit连在一块,绝逼报错,所以要有个空格!

TP默认也有两种方式进行分页,但效果真心没有自定义类的好看。
我是用了官方的“分页类和page方法的实现分页”,来分页的。

//商品显示,分页显示数据
public function showlist() {
    $goods = M('Goods'); //实例化数据库模型
    $list = $goods->where('goods_id')->order('goods_id desc')->page($_GET['p'] . ',6')->select(); //$_GET['p'] . ',6',的6也是每页需要显示几条数据
    $this->assign('list', $list); // 赋值数据集,显示数据
    $count = $goods->where('goods_id')->count(); // 查询满足要求的总记录数
    $Page = new \Think\Page($count, 6); // 实例化分页类 传入总记录数和每页显示的记录数
    $show = $Page->show(); // 分页显示输出
    $this->assign('page', $show); // 赋值分页输出
    $this->display(); // 输出模板
}

goods_id是看根据哪个表名来进行分类的,goods_id desc这里倒是比较人性化了,可以让出来的数据排序,这样可以让最新添加的数据在最前面,但每页显示的条数两个地方都要修改。其他模板上的数据输出和自定义类也是一样的。

最后修改:2016 年 01 月 19 日
如果觉得我的文章对你有用,请随意赞赏