- CakePHP 教程
- CakePHP - 首页
- CakePHP - 概述
- CakePHP - 安装
- CakePHP - 文件夹结构
- CakePHP - 项目配置
- CakePHP - 路由
- CakePHP - 控制器
- CakePHP - 视图
- CakePHP - 扩展视图
- CakePHP - 视图元素
- CakePHP - 视图事件
- CakePHP - 使用数据库
- CakePHP - 查看记录
- CakePHP - 更新记录
- CakePHP - 删除记录
- CakePHP - 服务
- CakePHP - 错误和异常处理
- CakePHP - 日志记录
- CakePHP - 表单处理
- CakePHP - 国际化
- CakePHP - 会话管理
- CakePHP - Cookie 管理
- CakePHP - 安全
- CakePHP - 验证
- CakePHP - 创建验证器
- CakePHP - 分页
- CakePHP - 日期和时间
- CakePHP - 文件上传
- CakePHP 有用资源
- CakePHP - 快速指南
- CakePHP - 有用资源
- CakePHP - 讨论
CakePHP - 分页
如果我们想要显示一个庞大的数据集,我们可以使用分页功能,并且 CakePHP 4 中提供了这个功能,非常易于使用。
我们有一个名为“articles”的表格,其中包含以下数据:
让我们使用分页功能以页面的形式显示数据,而不是将所有数据都一起显示。
示例
按照以下程序所示修改 config/routes.php 文件。
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('posts',['controller'=>'Posts','action'=>'index']); $builder->fallbacks(); });
在src/Controller/PostsController.php处创建一个PostsController.php文件。将以下代码复制到控制器文件中。如果已创建,请忽略。
src/Controller/PostsController.php
<?php namespace App\Controller; use App\Controller\AppController; class PostsController extends AppController { public function index(){ $this->loadModel('articles'); $articles = $this->articles->find('all')->order(['articles.id ASC']); $this->set('articles', $this->paginate($articles, ['limit'=> '3'])); } } ?>
使用以下方法获取 articles 表格中的数据:
$this->loadModel('articles'); $articles = $this->articles->find('all')->order(['articles.id ASC']);
要应用分页功能,我们将每页显示 3 条记录,操作如下:
$this->set('articles', $this->paginate($articles, ['limit'=> '3']));
这足以激活 articles 表格上的分页功能。
在src/Template处创建一个名为Posts的目录,并在该目录下创建一个名为 index.php 的View文件。将以下代码复制到该文件中。
src/Template/Posts/index.php
<div> <?php foreach ($articles as $key=>$article) {?> <a href="#"> <div> <p><?= $article->title ?> </p> <p><?= $article->details ?></p> </div> </a> <br/> <?php } ?> <ul class="pagination"> <?= $this->Paginator->prev("<<") ?> <?= $this->Paginator->numbers() ?> <?= $this->Paginator->next(">>") ?> </ul> </div>
页码列表的分页功能如下所示:
<ul class="pagination"> <?= $this->Paginator->prev("<<") ?> <?= $this->Paginator->numbers() ?> <?= $this->Paginator->next(">>") ?> </ul>
通过访问以下 URL 执行以上示例:
https://127.0.0.1/cakephp4/posts
输出
运行代码后,您将看到以下输出:
点击下面的数字切换到下一页,或使用“下一页”或“上一页”按钮。
例如
您将看到 page=2 附加到浏览器中的页面 URL。
广告