17.thinkphp的分页功能

一.分页功能

1.不管是数据库操作还是模型操作,都使用paginate()方法来实现(第一种方式);

php 复制代码
//查找user表所有数据,每页显示5条
returnView::fetch('index', [
 'list' => User::paginate(5)
 ]);

页数:

2.创建一个静态模版页面,并使用{volist}标签遍历列表;

php 复制代码
<table border="1">
 <tr>
 <th>编号</th>
 <th>姓名</th>
 <th>性别</th>
 <th>邮箱</th>
 <th>价格</th>
 </tr>
 {volist name='list' id='user'}
 <tr>
 <td>{$user.id}</td>
 <td>{$user.username}</td>
 <td>{$user.gender}</td>
 <td>{$user.email}</td>
 <td>{$user.price}</td>
 </tr>
 {/volist}
 </table>

3.分页功能还提供了一个固定方式,实现分页按钮,只需要设置相应的CSS即可;

php 复制代码
{$list|raw}
 <ul class="pagination">
 .pagination {
 list-style: none;
 margin: 0;
 padding: 0;
 }
 .pagination li {
 display: inline-block;
 padding: 20px;
 }
  1. 我们可以通过数组来传递多个参数(第二种方式),具体分页参数如下:
php 复制代码
$list = User::paginate([
 'list_rows' => 4,
 'var_page' => 'page',
 ]);

可以通过var_page来改变网址页数的变量。

  1. 也可以单独赋值分页的模版变量;
php 复制代码
// 获取分页显示
$page = $list->render();
 {$page|raw}
  1. 也可以单独获取到总记录数量;
php 复制代码
$total = $list->total();
  1. 如果你使用模型方式分页,则可以通过获取器修改字段值,而分页本身也可以;
php 复制代码
->each(function ($item, $key) {
 $item['gender'] = '【'.$item['gender'].'】';
 return $item;
 });
  1. 可以限定总记录数,比如,限定总记录数只有10条的页码;
php 复制代码
->paginate(5, 10);
  1. 也可以设置分页的页码为简洁分页,就是没有1,2,3,4这种,只有上下页;
php 复制代码
->paginate(5, true);
相关推荐
IT_陈寒3 分钟前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩4 分钟前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi7 分钟前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_8013 分钟前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体
大鹏说大话13 分钟前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库
哆来A梦没有口袋18 分钟前
干货精讲 | 初级CSS面试高频考题
前端·css·面试
夏贰四1 小时前
数据建模工具如何筑牢数据根基?数据建模工具怎样落实标准体系?
数据库·数学建模·数据建模工具
掘金011 小时前
EmbedPDF Vue 版 完整正文文档 全网首发
前端
OpenTiny社区1 小时前
操作ArkTS页面跳转及路由相关心得
前端·typescript·web·opentiny
xiaohua0708day1 小时前
Lodash库
前端·javascript·vue.js