YII2框架中分页组件的使用方法示例
程序员文章站
2023-11-21 19:40:16
本文实例讲述了yii2框架中分页组件的使用方法。分享给大家供大家参考,具体如下:当数据过多,无法一页显示时,我们经常会用到分页组件,yii2中已经帮我们封装好了分页组件。首先我们创建操作数据表的ar模...
本文实例讲述了yii2框架中分页组件的使用方法。分享给大家供大家参考,具体如下:
当数据过多,无法一页显示时,我们经常会用到分页组件,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>
最后效果如下:
上一篇: Oracle SQL性能优化系列学习三