YII2中分页组件的使用
发布时间:2020-12-14 13:37:53 所属栏目:大数据 来源:网络整理
导读:当数据过多,无法一页显示时,我们经常会用到分页组件,YII2中已经帮我们封装好了分页组件。 首先我们创建操作数据表的AR模型: ?phpnamespace appmodels;use yiidbActiveRecord;class MyUser extends ActiveRecord{ public static function tableName()
当数据过多,无法一页显示时,我们经常会用到分页组件,YII2中已经帮我们封装好了分页组件。 首先我们创建操作数据表的AR模型: <?php
namespace appmodels;
use yiidbActiveRecord;
class MyUser extends ActiveRecord
{
public static function tableName()
{
return '{{%user}}';
}
}
然后创建分页的控制器: <?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,]);
}
}
最后就是显示数据分页: <!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>
最后效果如下: (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |