laravel手动创建数组分页的实现代码
程序员文章站
2023-11-12 19:07:10
本文介绍了laravel手动创建数组分页的实现代码,分享给大家,具体如下:
laravel分页功能:
有几种方法可以对数据进行分页。最简单的是在 [查询语句构造器]...
本文介绍了laravel手动创建数组分页的实现代码,分享给大家,具体如下:
laravel分页功能:
有几种方法可以对数据进行分页。最简单的是在 [查询语句构造器] 或 [eloquent 查询] 中使用 paginate 或 simplepaginate 方法。
paginate用法如下:
//控制器中 $users = db::table('users')->paginate(15); return view('user.index', ['users' => $users]); //视图中 {{ $users->links() }}
效果如下:
「上一页」 「1」「2」「3」 「下一页」
simplepaginate用法如下:
//控制器中 $users = user::where('votes', '>', 100)->simplepaginate(15); return view('user.index', compact('users')); //视图中 {{ $users->links() }}
效果如下:
「上一页」 「下一页」
注意:
- 如果你只需要在分页视图中显示简单的「下一页」和「上一页」的链接,即不需要显示每个页码的链接,更推荐使用 simplepaginate 方法来执行更高效的查询。
- 目前,laravel 无法高效执行使用 groupby 语句的分页操作。如果你需要在分页结果集中使用 groupby,建议你查询数据库并手动创建分页器。
有时候可能会遇到这种情况,$dataa和$datab是从数据库取出的两个不同的数据集合,需要同时将$dataa和$datab分配到视图并进行分页展示,那这种情况怎么办呢?
这种情况可以采用laravel数组分页。
其实在laravel文档中已经有写如何自己使用分页类去分页了,但没有 详细说明。
手动创建分页
如果你想手动创建分页实例并且最终得到一个数组类型的结果,可以根据需求来创建 illuminatepaginationpaginator 或者 illuminatepaginationlengthawarepaginator 实例来实现。
具体可以看illuminatepaginationlengthawarepaginator中的这段代码:
public function __construct($items, $total, $perpage, $currentpage = null, array $options = []) { foreach ($options as $key => $value) { $this->{$key} = $value; } $this->total = $total; $this->perpage = $perpage; $this->lastpage = max((int) ceil($total / $perpage), 1); $this->path = $this->path !== '/' ? rtrim($this->path, '/') : $this->path; $this->currentpage = $this->setcurrentpage($currentpage, $this->pagename); $this->items = $items instanceof collection ? $items : collection::make($items); }
以下为具体实现代码:
//控制器中 public function index(liveservice $liveservice, request $request) { //数据a $dataa = user::where('status', 1)->get()->toarray(); //数据b $datab = user::where('status', 2)->get()->toarray(); $data = array_merge($dataa, $datab); //当前页数 默认1 $page = $request->page ?: 1; //每页的条数 $perpage = 4; //计算每页分页的初始位置 $offset = ($page * $perpage) - $perpage; //实例化lengthawarepaginator类,并传入对应的参数 $data = new lengthawarepaginator(array_slice($data, $offset, $perpage, true), count($data), $perpage, $page, ['path' => $request->url(), 'query' => $request->query()]); return view('admin.users.index', compact('data')); } //视图中 {{ $data->links() }}
以上基本就完成了数组分页,大致流程就是控制器获取到当前页数,实例化lengthawarepaginator
类并传入必要的参数,根据每页的条数利用array_slice()方法获取每页要显示的数据。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。