当前位置: 首页 > news >正文

Laravel 分页方案整理

经常使用laravel框架,对框架分页使用方案的整理

目录

框架分页方案

分析方法

使用paginate

应用场景

示例

返回结果

使用SQL

前端实现 

简单分页

应用场景

示例

 返回结果

前端实现

Skip take

应用场景

示例

基础示例

大数据示例

返回结果

使用SQL

前端实现

总结


框架分页方案

分析方法

分析使用SQL可以使用:

//开启记录 SQL 请求
DB::enableQueryLog();
/*数据库表操作*///输出 SQL 请求(在执行sql的下方使用)
print_r(DB::getQueryLog());die;

 

使用paginate

应用场景

适用于后台或者前后端混合且数据量中等或对响应速度要求不高的开发场景,

分页框架封装好了直接调用框架方法即可。

示例

paginate 方法能够自动判定当前页面正确的数量限制和偏移数。默认情况下,当前页数由 HTTP 请求所带的 ?page 参数来决定。该值由 Laravel 自动检测,并自动插入由分页器生成的链接;唯一参数为每页想要显示的数量,如下每页显示2条:

$res = DB::table('user')->paginate(2);
返回结果

打印返回结果如下:

使用SQL

可以明显的看到分页执行了两条SQL语句:

前端实现 

前端使用laravel blade模版引擎解析,使用laravel封装的分页方法直接渲染即可。

示例如下:

{{$paginate->appends($search)->links()}}

 效果:

 

简单分页

如果只需要在分页视图中简单的显示 “下一页” 和 “上一页” 链接,可以选择使用 simplePaginate 方法来进行更高效的查找。

应用场景

不显示总页数和数据条数,可以应用于大数据场景

示例

与paginate方法使用相同,只有一个参数即每页显示条数。

$res = DB::table('user')->select('id', 'real_name')->simplePaginate(2);
 返回结果

打印返回结果如下:

使用SQL

 

前端实现

前端使用laravel blade模版引擎解析,使用laravel封装的分页方法直接渲染即可。

{{$paginate->appends($search)->links()}}

 效果:

Skip take

应用场景

适合前后端分离场景,后端查询数据后通过接口返回,前端自定义实现分页。

示例
基础示例

使用skip和take方法,参数为数字类型,分别为偏移量和每页数据条数。

$res = DB::table('user')
->select('id', 'real_name')
->skip(0)
->take(2)
->get()
->toArray();

 

大数据示例

在数据量较大情况下,可以利用主键索引加快查询速度。

比如第一页可以使用id>0的,之后上一页最大的主键id(适用于顺序列表)。

示例如下:

$res = DB::table('user')
->where('id', '>', 0)
->select('id', 'real_name')
->skip(0)
->take(2)
->get()
->toArray();
返回结果

打印返回结果,如下:

 

使用SQL

 

前端实现

前端可以通过后端返回数据总条数或者是否有下页,来显示分页是否有下一页。

移动端也可以通过直接请求下一页无数据,来判断显示。

总结

Larael框架分页方案整理,总共介绍了三种分页方式,覆盖后台框架和API接口分页应用场景。

如果觉得后台的样式不够美观,还可以修改laravel框架分页封装样式。

http://www.lryc.cn/news/602895.html

相关文章:

  • 小智源码分析——音频部分(二)
  • 数据开源 | “白虎”数据集首批开源,迈出百万数据征途第一步
  • 阿里云正式开源 LoongSuite:打造 AI 时代的高性能低成本可观测采集套件
  • 自学嵌入式 day36 数据库
  • Java面试宝典:MySQL事务底层和高可用原理
  • MR-link-2:多效性顺式孟德尔随机化分析!
  • <PLC><西门子><modbusTCP>在西门子S7-1200系列PLC中,如何设置modbusTCP通讯?
  • 介绍一下static关键字
  • Go 原理之 GMP 并发调度模型
  • 未授权访问漏洞靶场(redis,MongoDB,Memcached...)
  • 从0到1学PHP(一):PHP 基础入门:开启后端开发之旅
  • 境外期货Level2高频Tick历史行情数据获取与应用指南
  • 墨者:SQL注入实战-MySQL
  • 中兴云电脑W101D2-晶晨S905L3A-2G+8G-安卓9-线刷固件包
  • **线程与进程的区别与联系**
  • Redis 部署模式详解
  • NBIOT模块 BC28通过MQTT协议连接到电信云
  • 【大模型LLM】梯度累积(Gradient Accumulation)原理详解
  • 微服务架构中 gRPC 的应用
  • Rust 最短路径、Tide、Partial、Yew、Leptos、数独实践案例
  • Hugging Face-环境配置
  • 洛谷 P10448 组合型枚举-普及-
  • HTML响应式SEO公司网站源码
  • 归雁思维:解锁自然规律与人类智慧的桥梁
  • 疯狂星期四文案网第22天运营日记
  • CFIHL: 水培生菜的多种叶绿素 a 荧光瞬态图像数据集
  • 递归算法的一些具体应用
  • TDSQL 技术详解
  • go‑cdc‑chunkers:用 CDC 实现智能分块 强力去重
  • Apache Ignite 的 JDBC Client Driver(JDBC 客户端驱动)