基于 Laravel ORM 的分页函数

chen

需要先安装 illuminate/databaseilluminate/pagination


1. 在 app/functions.php 里自定义函数

use Illuminate\Pagination\UrlWindow;
use Illuminate\Pagination\LengthAwarePaginator;

if (!function_exists('paginator')) {
    /**
     * laravel orm 分页器
     * @param LengthAwarePaginator $paginator
     * @param $template
     * @param $data
     * @return string|null
     */
    function paginator(LengthAwarePaginator $paginator, $template = 'pagination/layui', $data = [])
    {
        $window = UrlWindow::make($paginator);
        $elements = array_filter([
            $window['first'],
            is_array($window['slider']) ? '...' : null,
            $window['slider'],
            is_array($window['last']) ? '...' : null,
            $window['last'],
        ]);
        return view($template, array_merge($data, [
            'paginator' => $paginator,
            'elements' => $elements,
        ]))->rawBody();
    }
}

2. 自定义分页模板

illuminate/pagination自带了几个分页模板,在 vendor/illuminate/pagination/resources/views 目录可以找到。
我的项目里用的是 layui ,所以分页模板自定义了 pagination/layui.blade.php,代码如下:

@if ($paginator->hasPages())
<div class="layui-box layui-laypage layui-laypage-default" id="layui-laypage-18">
    <a class="layui-laypage-prev {{ $paginator->onFirstPage() ? 'layui-disabled' : '' }}" href="{{ $paginator->onFirstPage() ? 'javascript:void(0);' : $paginator->previousPageUrl() }}">上一页</a>
    @foreach($elements as $element)
        @if (is_string($element))
            <span class="layui-laypage-spr">{{ $element }}</span>
        @endif
        @if (is_array($element))
            @foreach ($element as $page => $url)
                @if ($page == $paginator->currentPage())
                    <span class="layui-laypage-curr">
                        <em class="layui-laypage-em layui-bg-red"></em>
                        <em>{{ $page }}</em>
                    </span>
                @else
                    <a href="{{ $url }}">{{ $page }}</a>
                @endif
            @endforeach
        @endif
    @endforeach
    <a class="layui-laypage-next {{ !$paginator->hasMorePages() ? 'layui-disabled' : '' }}" href="{{ $paginator->hasMorePages() ? $paginator->nextPageUrl() : 'javascript:void(0);' }}">下一页</a>
</div>
@endif

3. 使用

// 控制器
class IndexController
{
    $items = Model::query()->paginate();
    return view('index/index', ['items' => $items]);
}
// 模板文件
{!! paginator($items) !!}

4. 效果截图

截图

636 1 1
1个评论

mincon

插个眼

  • 暂无评论

chen

760
积分
0
获赞数
0
粉丝数
2022-01-12 加入
×
🔝