zoukankan      html  css  js  c++  java
  • YII2中分页组件的使用

    当数据过多,无法一页显示时,我们经常会用到分页组件,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>
    

    最后效果如下:

  • 相关阅读:
    python运行js---execjs 使用
    使用百度文字识别API进行图片中文字的识别
    cpca 使用python提取中文地址描述中的省市区信息
    Android 设备信息获取详解
    Android实现左滑退出Activity(完美封装)
    Postman测试Soap协议接口
    如何使用postman带Token测试接口?
    Postman高级使用——Tests 断言校验返回结果
    Android Service完全解析,关于服务你所需知道的一切(下)
    Android Service完全解析,关于服务你所需知道的一切(上)
  • 原文地址:https://www.cnblogs.com/jkko123/p/8668419.html
Copyright © 2011-2022 走看看