编程 thinkphp分页扩展

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

##基于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);
    }
}
复制全文 生成海报 前端 后端 开发

推荐文章

如何在 Vue 3 中使用 Vuex 4?
2024-11-17 04:57:52 +0800 CST
JS 箭头函数
2024-11-17 19:09:58 +0800 CST
一些好玩且实用的开源AI工具
2024-11-19 09:31:57 +0800 CST
阿里云免sdk发送短信代码
2025-01-01 12:22:14 +0800 CST
资源文档库
2024-12-07 20:42:49 +0800 CST
黑客帝国代码雨效果
2024-11-19 01:49:31 +0800 CST
npm速度过慢的解决办法
2024-11-19 10:10:39 +0800 CST
PHP 压缩包脚本功能说明
2024-11-19 03:35:29 +0800 CST
js一键生成随机颜色:randomColor
2024-11-18 10:13:44 +0800 CST
25个实用的JavaScript单行代码片段
2024-11-18 04:59:49 +0800 CST
Vue3中的组件通信方式有哪些?
2024-11-17 04:17:57 +0800 CST
Elasticsearch 聚合和分析
2024-11-19 06:44:08 +0800 CST
15 个你应该了解的有用 CSS 属性
2024-11-18 15:24:50 +0800 CST
任务管理工具的HTML
2025-01-20 22:36:11 +0800 CST
详解 Nginx 的 `sub_filter` 指令
2024-11-19 02:09:49 +0800 CST
一个简单的打字机效果的实现
2024-11-19 04:47:27 +0800 CST
如何在Vue 3中使用Ref访问DOM元素
2024-11-17 04:22:38 +0800 CST
程序员茄子在线接单