时间:2021-05-26
本文介绍了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() }}效果如下:
「上一页」 「下一页」
注意:
有时候可能会遇到这种情况,$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()方法获取每页要显示的数据。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP实现对数组分页处理方法。分享给大家供大家参考,具体如下:最近用到了用数组数据分页,这里整理了一下,具体代码如下:pageArray=$arr
基于Laravel5.5在项目实施过程中,需要对从接口中获取的数据(或者通过搜索工具查询出来的数据)进行分页一、创建手动分页在laravel自带的分页中,一般是
本文实例讲述了php数组分页实现方法。分享给大家供大家参考,具体如下:3,'clickDate'=>'2010-10-11'),array('clicks'=>
本文实例讲述了Laravel手动分页实现方法。分享给大家供大家参考,具体如下:这里的演示实例基于Laravel的5.2版本在开发过程中有这么一种情况,你请求Ja
本文实例讲述了Laravel5.1框架分页展示实现方法。分享给大家供大家参考,具体如下:Laravel为我们提供了一套分页的逻辑,我们无需自己实现分页逻辑,只需