编程 thinkphp分页扩展

2024-11-18 10:18:09 +0800 CST views 2311

##基于layui的tp5扩展

<?php
namespace org;
use think\Paginator;
class Layuipage extends Paginator
{
    /**
     * 上一页按钮
     * @param string $text
     * @return string
     */
    protected function getPreviousButton($text = "&laquo;")
    {

        if ($this->currentPage() <= 1) {
            return $this->getDisabledTextWrapper($text);
        }

        $url = $this->url(
            $this->currentPage() - 1
        );

        return $this->getPageLinkWrapper($url, $text);
    }

    /**
     * 下一页按钮
     * @param string $text
     * @return string
     */
    protected function getNextButton($text = '&raquo;')
    {
        if (!$this->hasMore) {
            return $this->getDisabledTextWrapper($text);
        }

        $url = $this->url($this->currentPage() + 1);

        return $this->getPageLinkWrapper($url, $text);
    }

    /**
     * 页码按钮
     * @return string
     */
    protected function getLinks()
    {
        if ($this->simple)
            return '';

        $block = [
            'first'  => null,
            'slider' => null,
            'last'   => null
        ];

        $length = 3;

        if ($this->lastPage < $length * 4) {
            $block['first'] = $this->getUrlRange(1, $this->lastPage);
        } elseif ($this->currentPage <= $length * 2) {
            $block['first'] = $this->getUrlRange(1, $length * 2 + 2);
            $block['last']  = $this->getUrlRange($this->lastPage - 1, $this->lastPage);
        } elseif ($this->currentPage > ($this->lastPage - $length * 2)) {
            $block['first'] = $this->getUrlRange(1, 2);
            $block['last']  = $this->getUrlRange($this->lastPage - $length * 2 + 2, $this->lastPage);
        } else {
            $block['first']  = $this->getUrlRange(1, 2);
            $block['slider'] = $this->getUrlRange($this->currentPage - $length, $this->currentPage + $length);
            $block['last']   = $this->getUrlRange($this->lastPage - 1, $this->lastPage);
        }


        $html = '';

        if (is_array($block['first'])) {
            $html .= $this->getUrlLinks($block['first']);
        }

        if (is_array($block['slider'])) {
            $html .= $this->getDots();
            $html .= $this->getUrlLinks($block['slider']);
        }

        if (is_array($block['last'])) {
            $html .= $this->getDots();
            $html .= $this->getUrlLinks($block['last']);
        }

        return $html;
    }


    /**
     * 渲染分页html
     * 如果需要定义其他的样式,可以在这里自由定义
     * @return mixed
     */
    public function render()
    {
        if ($this->hasPages()) {
            if ($this->simple) {
                
                //简洁模式代码
                return sprintf(
                    '<div class="layui-box layui-laypage layui-laypage-default" >%s %s</div>',
                    $this->getPreviousButton("上一页"),
                    $this->getNextButton("下一页")
                );
            } else {
                //普通模式代码
                return sprintf(
                    '<div class="layui-box layui-laypage layui-laypage-default" >%s %s %s</div>',
                    $this->getPreviousButton("上一页"),
                    $this->getLinks(),
                    $this->getNextButton("下一页")
                );
            }
        }
    }


    /**
     * 生成一个可点击的按钮
     *
     * @param  string $url
     * @param  int $page
     * @return string
     */
    protected function getAvailablePageWrapper($url, $page)
    {
        return '<a href="' . htmlentities($url) . '">' . $page . '</a>';
        
    }

    /**
     * 生成一个禁用的按钮
     *
     * @param  string $text
     * @return string
     */
    protected function getDisabledTextWrapper($text)
    {
        return '<a href="javascript:;" class="layui-laypage-prev layui-disabled">'.$text.'</a>';
        
    }

    /**
     * 生成一个激活的按钮
     *
     * @param  string $text
     * @return string
     */
    protected function getActivePageWrapper($text)
    {
        return '<span class="layui-laypage-curr"><em class="layui-laypage-em"></em><em>' . $text . '</em> </span>';
        
    }

    /**
     * 生成省略号按钮
     *
     * @return string
     */
    protected function getDots()
    {
        return $this->getDisabledTextWrapper('...');
    }

    /**
     * 批量生成页码按钮.
     *
     * @param  array $urls
     * @return string
     */
    protected function getUrlLinks(array $urls)
    {
        $html = '';

        foreach ($urls as $page => $url) {
            $html .= $this->getPageLinkWrapper($url, $page);
        }

        return $html;
    }

    /**
     * 生成普通页码按钮
     *
     * @param  string $url
     * @param  int $page
     * @return string
     */
    protected function getPageLinkWrapper($url, $page)
    {
        if ($page == $this->currentPage()) {
            return $this->getActivePageWrapper($page);
        }

        return $this->getAvailablePageWrapper($url, $page);
    }
}
复制全文 生成海报 前端 后端 开发

推荐文章

Rust 高性能 XML 读写库
2024-11-19 07:50:32 +0800 CST
软件定制开发流程
2024-11-19 05:52:28 +0800 CST
开发外贸客户的推荐网站
2024-11-17 04:44:05 +0800 CST
快速提升Vue3开发者的效率和界面
2025-05-11 23:37:03 +0800 CST
Vue3中的JSX有什么不同?
2024-11-18 16:18:49 +0800 CST
Vue3 组件间通信的多种方式
2024-11-19 02:57:47 +0800 CST
禁止调试前端页面代码
2024-11-19 02:17:33 +0800 CST
Elasticsearch 条件查询
2024-11-19 06:50:24 +0800 CST
程序员出海搞钱工具库
2024-11-18 22:16:19 +0800 CST
Nginx 负载均衡
2024-11-19 10:03:14 +0800 CST
Rust 并发执行异步操作
2024-11-18 13:32:18 +0800 CST
Rust async/await 异步运行时
2024-11-18 19:04:17 +0800 CST
18个实用的 JavaScript 函数
2024-11-17 18:10:35 +0800 CST
JavaScript设计模式:装饰器模式
2024-11-19 06:05:51 +0800 CST
使用Vue 3实现无刷新数据加载
2024-11-18 17:48:20 +0800 CST
Vue中如何处理异步更新DOM?
2024-11-18 22:38:53 +0800 CST
PHP来做一个短网址(短链接)服务
2024-11-17 22:18:37 +0800 CST
go发送邮件代码
2024-11-18 18:30:31 +0800 CST
PyMySQL - Python中非常有用的库
2024-11-18 14:43:28 +0800 CST
Nginx 反向代理
2024-11-19 08:02:10 +0800 CST
html折叠登陆表单
2024-11-18 19:51:14 +0800 CST
程序员茄子在线接单