例如,在控制器中查询数据 paginate 方法–使用分页查询
$blogs = Blog::where('status', '=', 1)->paginate(2);
return view('index.index', ['blogs' => $blogs]);
在视图中使用分页
@foreach($blogs as $v)
<div class="article-body">
<div>
<span class="article-author">{{$v->user_id}}</span>
<span class="article-time">{{($v->updated_at)->diffForHumans()}}</span>
</div>
<h2 class="font-weight-bold my-3 article-title">
<a class="text-dark" href="{{route('blog.show',['blog'=>1])}}">{{$v->title}}</a>
</h2>
<div class="article-des">{{$v->content}}</div>
<div>
<a href="#" class="badge badge-warning mt-3 articel-category">{{categories()[$v->category_id]}}
</a>
</div>
</div>
<hr>
@endforeach
{{$blogs->links()}}
但是,使用分页的话,样式是很乱的,所以,需要去指定一些分页使用的样式 在app\Providers\AppServiceProvider.php中的boot方法
这样就指定了使用的样式,前台是,有bootstrap这个样式文件
Paginator::useBootstrap();
这个就是简单使用分页的基本过程了。
简单分页
如果只需要在分页视图中简单地显示「下一页」和「上一页」的链接,你可以使用 simplePaginate 方法来执行更高效地查询
$blogs = Blog::where('status', '=', 1)->simplePaginate(2);
附加参数到分页链接 可以使用 appends 方法向分页链接中添加查询参数。例如,要在每个分页链接中添加 sort=votes 这种方式基本都是用在搜索里面,因为搜索的时候如果数据很多,就即要带搜索变量和分页
{{ $users->appends(['sort' => 'votes'])->links() }}
如果想要把所有的查询参数值添加到分页链接,可以使用 withQueryString 方法 有时候,在搜索的时候有很多参数,不可能像上一个一样去一个一个添加进去
{{ $users->withQueryString()->links() }}
自定义分页视图
默认情况下,渲染视图来显示分页链接是与 Tailwind CSS 框架兼容的。然而,如果你不想使用 Tailwind,你可以自由的选择你自己定制的视图来渲染这些链接。在调用分页器实例的 links 方法时,将视图名称作为第一个参数传递给该方法
{{ $paginator->links('view.name') }}
自定义分页视图最简单的方法是使用 vendor:publish 命令将它们输出到 resources/views/vendor 目录
php artisan vendor:publish --tag=laravel-pagination
执行该命令后,会生成分页视图
如果想要定义不同的文件作为默认的分页视图,你需要在 AppServiceProvider 中使用分页器的 defaultView 和 defaultSimpleView 方法
这个就是说有时候很多地方都需要使用自定义的分页视图,但是又不可能每个使用的地方都去传这个分页视图把,所以,就可以使用这种方式去默认使用自定义视图
public function boot()
{
Paginator::defaultView('view-name');
Paginator::defaultSimpleView('view-name');
}
完整使用自定义分页的流程
第一,自己写一份分页视图
第二,去需要使用视图的地方使用自定义分页视图 使用自定义视图有两种方式 第一种:在使用分页函数里面传递视图,路径是从view下面开始计算
{{ $paginator->links('vendor.pagination.my-page') }}
第二种:在boot()里面修改分页默认视图
Paginator::defaultView('vendor.pagination.my-page');
Paginator::defaultSimpleView('vendor.pagination.my-page');
|