阅读 133

YII2框架中分页组件的使用方法示例

这篇文章主要介绍了YII2框架中分页组件的使用方法,结合实例形式详细分析了YII2框架中分页组件相关控制器、模型的创建及分页实现方法,需要的朋友可以参考下

本文实例讲述了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>

最后效果如下:



文章分类
后端
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐