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);
相关推荐
Momo__26 分钟前
VueUse createReusableTemplate —— 单文件组件内的模板复用神器
前端·vue.js
程序员小富32 分钟前
我开源了一个开发者专属的智能 JSON 工具,得到了媳妇高度认可
前端·vue.js·后端
小小小小宇32 分钟前
程序员如何给 LLM 装工具以及看懂推理过程
前端
写代码的皮筏艇32 分钟前
React中的forwardRef
前端·react.js·面试
槑有老呆41 分钟前
花三个月工资请了个 AI 程序员,结果它连青岛啤酒股价都查不了
前端
风骏时光牛马43 分钟前
Verilog开发常见问题汇总解析
前端
子兮曰1 小时前
AI Coding Method Map:一张图看懂 AI 编程的完整链路
前端·人工智能·后端
weedsfly1 小时前
语法糖褪去之后——Babel 转译产物中的 JavaScript 本貌
前端·javascript
JustHappy1 小时前
「软件设计思想杂谈🤔」“切图仔”也能懂编译原理?框架源码也许没那么难。聊聊 Vue 的编译(上)
前端·javascript·vue.js