Laravel 限制条数后再分页

laravel 自带开箱即用的分页,使用起来如丝般顺滑。默认情况下是对所有记录进行分页,现在我们有这样的需求:限制用户只能看到前 30 页。第一想法就是用 limit 限制条数后再调用分页,如:

$per_page = 15; // 每页条数
$limit_page = 30; // 限制总页数
$data = Article::orderBy('id', 'desc')->limit($per_page * $limit_page)->paginate($per_page);

此种写法并不能生效,因为 paginate 方法中内置的 limit 会替换掉我们的 limit

虽然我们可以根据文档,手动调用分页的相关方法,自己撸一个分页。但这种实现方式太繁琐,相当于造轮子。我们可以切换一下思维来解决:

  • 取出要展示的条数的最小 id

  • 在总记录中设置 id 大于上一条件得到的最小 id

即,用 where 替换 limit 限制总条数

$last_id = Article::orderBy('id', 'desc')
    ->limit($per_page * $limit_page)
    ->pluck('id')
    ->sort()
    ->first();
$data = Article::orderBy('id', 'desc')
    ->where('id', '>', $last_id)
    ->paginate($per_page);

原文 https://www.itshutong.com/354.html

php
本作品采用《CC 协议》,转载必须注明作者和本文链接
it书童
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 1
Epona

我觉得在控制器中 判断分页参数大于30 直接报错会笔这个少处理内容😂

4年前 评论
it书童 (楼主) 4年前
Epona (作者) 4年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!