CakePHP 分页
cakephp 分页
如果我们想显示一组庞大的数据,我们可以使用分页,这个功能在 cake php 4 中可用,非常好用。
我们有一个名为"文章"的表格,其中包含以下数据:
让我们使用分页来以页面的形式显示数据,而不是将它们全部显示。
示例
在 config/routes.php 文件中进行更改,如以下程序所示。
config/routes.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
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'])); } } ?>
文章表中的数据使用:
$this->loadmodel('articles'); $articles = $this->articles->find('all')->order(['articles.id asc']);
应用分页,我们w应该显示每条记录有 3 个数据,并按照以下方式进行:
$this->set('articles', $this->paginate($articles, ['limit'=> '3']));
这足以在 文章 表上激活分页。
在 src/template 创建一个目录 posts,然后在该目录下创建一个名为 index.php 的 view 文件。将以下代码复制到该文件中。
src/template/posts/index.php
foreach ($articles as $key=-->$article) {?><a href="#"></a> } <ul class="pagination"> <!--?= $this--->paginator->prev("<<") ?> <!--?= $this--->paginator->numbers() ?> <!--?= $this--->paginator->next(">>") ?></ul><!--?= $article--->title ?>
<!--?= $article--->details ?>
页面列表的分页如下:
<ul class="pagination"> <!--?= $this--->paginator->prev("<<") ?> <!--?= $this--->paginator->numbers() ?> <!--?= $this--->paginator->next(">>") ?></ul>
通过访问以下 url 执行上述示例:
http://localhost/cakephp4/posts
输出
当您运行代码时,您将看到以下输出:
点击下面的数字,切换到下一页,或者使用下一个或上一个按钮。
例如
您将看到 page=2 附加到浏览器中的页面 url。