问题描述
在学习laravel框架的时候使用了links函数实现分页功能,但是遇到了分页布局混乱的情况.
代码如下:
<div class="card">
<div class="card-header">
用户列表
</div>
<div class="card-body">
<table class="table">
<thead>
<tr>
<th>编号</th>
<th>昵称</th>
<th>操作</th>
</tr>
</thead>
<tbody>
@foreach($users as $user)
<tr>
<td scope="row">{{$user['id']}}</td>
<td>{{$user['name']}}</td>
<td>
</td>
</tr>
@endforeach
</tbody>
</table>
</div>
<div class="card-footer text-muted">
{{$users->links()}}
</div>
</div>
效果如下:
解决方案
使用 vendor:publish 命令导出视图文件到resources/views/vendor 目录(index.blade.php是调用了links的视图文件)
artisan vendor:publish --tag=index.blade.php
生成各种分页样式模板
bootstrap-4.blade.php源码:
@if ($paginator->hasPages())
<nav>
<ul class="pagination">
{{-- Previous Page Link --}}
@if ($paginator->onFirstPage())
<li class="page-item disabled" aria-disabled="true" aria-label="@lang('pagination.previous')">
<span class="page-link" aria-hidden="true">‹</span>
</li>
@else
<li class="page-item">
<a class="page-link" href="{{ $paginator->previousPageUrl() }}" rel="prev" aria-label="@lang('pagination.previous')">‹</a>
</li>
@endif
{{-- Pagination Elements --}}
@foreach ($elements as $element)
{{-- "Three Dots" Separator --}}
@if (is_string($element))
<li class="page-item disabled" aria-disabled="true"><span class="page-link">{{ $element }}</span></li>
@endif
{{-- Array Of Links --}}
@if (is_array($element))
@foreach ($element as $page => $url)
@if ($page == $paginator->currentPage())
<li class="page-item active" aria-current="page"><span class="page-link">{{ $page }}</span></li>
@else
<li class="page-item"><a class="page-link" href="{{ $url }}">{{ $page }}</a></li>
@endif
@endforeach
@endif
@endforeach
{{-- Next Page Link --}}
@if ($paginator->hasMorePages())
<li class="page-item">
<a class="page-link" href="{{ $paginator->nextPageUrl() }}" rel="next" aria-label="@lang('pagination.next')">›</a>
</li>
@else
<li class="page-item disabled" aria-disabled="true" aria-label="@lang('pagination.next')">
<span class="page-link" aria-hidden="true">›</span>
</li>
@endif
</ul>
</nav>
@endif
生成了模板之后在控制器里可以设置模板默认样式,可以自行修改
Paginator::defaultView('vendor.pagination.bootstrap-4');
此时刷新就可以看到样式正常了