首页 > 作文

laravel手动创建数组分页的实现代码

更新时间:2023-04-06 17:33:52 阅读: 评论:0

本文介绍了laravel手动创建数组分页的实现代码,分享给大家,具体如下:

laravel分页功能:

有几种方法可以对数据进行分页。最简单的是在 [查询语句构造器] 或 [eloquent 查询] 中使用 paginate 或 simplepaginate 方法。

paginate用法如下:

//控制器中$urs = db::table('urs')->paginate(15);return view('ur.index', ['urs' => $urs]);//视图中{{ 雾霾歌曲$urs->links() }}

效果如下:

「上一页」 「1」「2」「3」 「下一页」

simplepaginate用法如下:

//控制器中$urs = ur::where('votes', '>', 100)->simplepaginate(15);return view('ur.index', compact('urs'));//视图中{{ $urs->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->perpa经典歌名ge = $perpage;  $this->lastpage 奶茶怎么做= max((int) ceil($total / $perpage), 1);  $this->path = $this->path !== '/' ? rtrim($this->path, '/') : $this->path;  $this->currentpage = $this->tcurrentpage($currentpage, $this->pagename);  $this->items = $items instanceof collection ? $items : collection::make($items); }

以下为具体实现代码:

//控制器中public function index(livervice $livervice, request $request) {  //数据a  $dataa = ur::where('status', 1)->get()->toarray();  //数据b  $datab = ur::where('status', 2)->get()->toarray();  $data = array_merge($dataa, $datab);  //当前页数 默认1  $page = $request->page ?: 1;  //每页的条数  $perpage = 4;  //计算每页分页的初始位置  $offt = ($page * $perpage) - $perpage;   //实例化lengthawarepaginator类,并传入对应的参数  $data = new lengthawarepaginator(array_slice($data, $offt, $perpage, true), count($data), $perpage,   $page, ['path' => $request->url(), 'query' => $request->query()]);  return view('admin.urs.index', compact('data')); }//视图中{{ $data->links() }}

以上基本就完成了数组分页,大致流程就是控制器获取到当前页数,实例化lengthawarepaginator类并传入必要的参数,根据每页的条数利用array_slice()方法获取每页要显示的数据。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。

本文发布于:2023-04-06 17:33:51,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/56687a328bb2e34bd9baad3014c46a3d.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:laravel手动创建数组分页的实现代码.doc

本文 PDF 下载地址:laravel手动创建数组分页的实现代码.pdf

标签:分页   视图   每页   数组
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图