本文实例讲述了YII2框架中分页组件的使用方法。分享给大家供大家参考,具体如下:
当数据过多,无法一页显示时,我们经常会用到分页组件,YII2中已经帮我们封装好了分页组件。
首先我们创建操作数据表的AR模型:
代码语言:javascript复制<?php
namespace appmodels;
use yiidbActiveRecord;
class MyUser extends ActiveRecord
{
public static function tableName()
{
return '{{%user}}';
}
}
然后创建分页的控制器:
代码语言:javascript复制<?php
namespace appcontrollers;
use YII;
use appmodelsMyUser;
use yiidataPagination;
use yiiwebController;
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,
]);
}
}
最后就是显示数据分页:
代码语言:javascript复制<!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 yiiwidgetsLinkPager::widget([
'pagination' = $page,
'firstPageLabel' = '首页',
'lastPageLabel' = '尾页',
'nextPageLabel' = '下一页',
'prevPageLabel' = '上一页',
//设置class样式
'options' = ['class' = 'page'],
]) ?
</body
</html
最后效果如下:
更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。