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);
网友评论