美文网首页
Laravel 限制条数后再分页

Laravel 限制条数后再分页

作者: 闲睡猫 | 来源:发表于2019-11-11 17:53 被阅读0次

    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

    相关文章

      网友评论

          本文标题:Laravel 限制条数后再分页

          本文链接:https://www.haomeiwen.com/subject/nxtxictx.html