当数据过多,无法一页显示时,我们经常会用到分页组件,YII2中已经帮我们封装好了分页组件。

首先我们创建操作数据表的AR模型:

<?php

namespace app\models;

use yii\db\ActiveRecord;

class MyUser extends ActiveRecord
{
public static function tableName()
{
return '{{%user}}';
}
}

然后创建分页的控制器:

<?php

namespace app\controllers;

use YII;
use app\models\MyUser;
use yii\data\Pagination;
use yii\web\Controller; class IndexController extends Controller
{
public function actionIndex()
{
$name = YII::$app->request->get('name', '');
$where = '1=1 ';
$param = []; //如果查询条件很多,可以按这种方式,拼where条件
if (!empty($name)) {
$where .= "AND name=:name";
$param = array_merge($param, [':name' => $name]);
} //设置分页大小,为了演示,我写成了2
$pageSize = 2;
$user = MyUser::find()->where($where, $param); //创建分页组件
$page = new Pagination([
//总的记录条数
'totalCount' => $user->count(),
//分页大小
'pageSize' => $pageSize,
//设置地址栏当前页数参数名
'pageParam' => 'p',
//设置地址栏分页大小参数名
'pageSizeParam' => 'pageSize',
]); //获取数据
$data = $user->orderBy('id DESC')
->offset($page->offset)
->limit($page->limit)
->asArray()
->all(); return $this->renderPartial('index', [
'data' => $data,
'page' => $page,
]);
}
}

最后就是显示数据分页:

<!doctype html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<title>分页显示</title>
<style>
.page li {
display: inline-block;
border: 1px solid #ccc;
border-radius: 3px;
padding: 2px 3px;
} .page li.active a {
font-weight: bold;
} .page li a {
text-decoration: none;
} .page li a, .page li span {
color: #666;
}
</style>
</head>
<body>
<ul>
<?php foreach ($data as $item): ?>
<li><?php echo $item['id']; ?>    <?php echo $item['name']; ?></li>
<?php endforeach; ?>
</ul>
<?php
echo \yii\widgets\LinkPager::widget([
'pagination' => $page,
'firstPageLabel' => '首页',
'lastPageLabel' => '尾页',
'nextPageLabel' => '下一页',
'prevPageLabel' => '上一页',
//设置class样式
'options' => ['class' => 'page'],
]) ?>
</body>
</html>

最后效果如下:

最新文章

  1. cve-2015-5199漏洞分析
  2. JSP自定义标签/自定义标签打包
  3. java中TreeSet集合如何实现元素的判重
  4. HTML DOM学习之一
  5. Windows环境变量设置无效解决办法——DOS窗口设置环境变量
  6. Linux 下监控用户最大进程数参数(nproc)是否到达上限
  7. galera mysql 多主复制启动顺序及命令
  8. HTML5 智能表单
  9. EclEmma单元测试覆盖率统计插件
  10. MVC5中使用Log4Net
  11. Maven 构建浏览器解析userAgent类
  12. java文件上传 关键代码
  13. MyBatis源码解析(九)——Type类型模块之类型处理器注册器(TypeHandlerRegistry)
  14. uva-10026-贪心
  15. MySQL数据库相关操作
  16. 深入理解Java虚拟机--阅读笔记一
  17. 根据经纬度获取位置描述:百度API与高德API的区别
  18. ip_conntrack table full dropping packet解决方案
  19. 2016级算法第六次上机-D.AlvinZH的学霸养成记V
  20. MFC学习(一)

热门文章

  1. 浏览器唤起APP的思路(本文转载)
  2. VC++ 获取系统时间、程序运行时间(精确到秒,毫秒)的五种方法
  3. winform下利用webBrowser执行javascript
  4. Win8系统本地连接显示为网络2
  5. JSTL标签不起作用的解决办法
  6. python 稀疏向量和矩阵的表示形式
  7. 开始jQuery学习之旅
  8. JAVA回文
  9. maven &lt;scope&gt;provided&lt;/scope&gt;
  10. target=_blank攻击