设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 创业者 手机 数据
当前位置: 首页 > 综合聚焦 > 编程要点 > 正文

YII2的分页组件要怎么使用?办法是什么?

发布时间:2022-02-18 10:55 所属栏目:13 来源:互联网
导读:YII2框架中分页组件怎么使用?在做开发时,如果数据太多,一页显示不全,那么就需要做分页。在YII2框架中已经帮我们封装好了分页组件,下面我们就来看看是如何使用的。 首先我们创建操作数据表的AR模型: ?php namespace app\models; use yii\db\ActiveRecor
      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> 

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读