CakePHP - 分页



如果我们想要显示一个庞大的数据集,我们可以使用分页功能,并且 CakePHP 4 中提供了这个功能,非常易于使用。

我们有一个名为“articles”的表格,其中包含以下数据:

Options

让我们使用分页功能以页面的形式显示数据,而不是将所有数据都一起显示。

示例

按照以下程序所示修改 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

输出

运行代码后,您将看到以下输出:

Article

点击下面的数字切换到下一页,或使用“下一页”或“上一页”按钮。

例如

Article1

您将看到 page=2 附加到浏览器中的页面 URL。

广告