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

 更新时间:2020年03月12日 11:12:52   转载 作者:怀素真  
这篇文章主要介绍了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>

最后效果如下:

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

相关文章

  • PHP结合jQuery.autocomplete插件实现输入自动完成提示的功能

    PHP结合jQuery.autocomplete插件实现输入自动完成提示的功能

    本文将使用jquery ui的autocomplete插件,结合后端PHP,数据源通过PHP读取mysql数据表的数据,有需要的朋友可以参考一下。
    2015-04-04
  • 浅谈PHP值mysql操作类

    浅谈PHP值mysql操作类

    下面小编就为大家带来一篇浅谈PHP值mysql操作类。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • php导出csv文件,可导出前导0实例代码

    php导出csv文件,可导出前导0实例代码

    下面小编就为大家带来一篇php导出csv文件,可导出前导0实例代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • Yaf框架封装的MySQL数据库操作示例

    Yaf框架封装的MySQL数据库操作示例

    这篇文章主要介绍了Yaf框架封装的MySQL数据库操作,结合实例形式分析了Yaf框架基于PDO操作MySQL数据库的相关配置、连接、增删改查、统计等相关操作技巧,需要的朋友可以参考下
    2019-03-03
  • Ubuntu VPS中wordpress网站打开时提示”建立数据库连接错误”的解决办法

    Ubuntu VPS中wordpress网站打开时提示”建立数据库连接错误”的解

    这篇文章给大家介绍的是在Ubuntu VPS中wordpress网站打开时提示”建立数据库连接错误”的解决办法,相信"建立数据库连接错误"大家并不陌生,最近我在做一个项目的时候就又遇到了这个问题,现在将我解决的步骤分享给大家,希望对同样遇到这个问题的朋友们能有所帮助。
    2016-11-11
  • php设计模式之原型模式分析【星际争霸游戏案例】

    php设计模式之原型模式分析【星际争霸游戏案例】

    这篇文章主要介绍了php设计模式之原型模式,结合星际争霸游戏案例形式分析了PHP原型模式的原理、使用方法与操作注意事项,需要的朋友可以参考下
    2020-03-03
  • Laravel 5框架学习之环境与配置

    Laravel 5框架学习之环境与配置

    本文给大家主要介绍的是Laravel5框架中的环境配置,给大家详细介绍了.env的配置文件,包含的数据库配置信息的详细解释,这里推荐给大家,有需要的小伙伴参考下。
    2015-04-04
  • Laravel框架实现调用百度翻译API功能示例

    Laravel框架实现调用百度翻译API功能示例

    这篇文章主要介绍了Laravel框架实现调用百度翻译API功能,结合实例形式分析了基于Laravel框架的百度翻译API调用相关操作技巧,需要的朋友可以参考下
    2019-05-05
  • PHP环境搭建(php+Apache+mysql)

    PHP环境搭建(php+Apache+mysql)

    这篇文章主要为大家详细介绍了PHP环境搭建,包括php、Apache、mysql环境安装,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • PHP等比例压缩图片的实例代码

    PHP等比例压缩图片的实例代码

    本文通过一段简单的代码给大家介绍PHP等比例压缩图片的方法,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-07-07

最新评论