前言:

说明下我们本篇文章都要讲哪些内容

分页的使用,一步一步的教你怎么做

分页类LinkPager和Pagination都可以自定义哪些属性

分页类LinkPager如何扩展成我们所需要的

第一步,我们来看看yii2自带的分页类该如何去使用?

1、controller action

use yii\data\Pagination;

$query = Article::find()->where(['status' => 1]);

$countQuery = clone $query;

$pages = new Pagination(['totalCount' => $countQuery->count()]);

$models = $query->offset($pages->offset)

->limit($pages->limit)

->all();

return $this->render('index', [

'models' => $models,

'pages' => $pages,

]);

2、View

use yii\widgets\LinkPager;

//循环展示数据

foreach ($models as $model) {

// ......

}

//显示分页页码

echo LinkPager::widget([

'pagination' => $pages,

])

代码基本上可以完全拷贝,修改部分数据即可,相信大多数人都是看得懂的。

我们接下来看第二步,自带的分页类都可以定义哪些属性

首先我们说说LinkPager组件

.pagination参数必填,这个是我们Pagination类的实例

默认分页类是下面这个样子的

.上下页按钮以及10个按钮

首先,我们把上下页的按钮修改成中文

= LinkPager::widget([

'pagination' => $pages,

'nextPageLabel' => '下一页',

'prevPageLabel' => '上一页',

]); ?>

如果你不想要显示上下页,可以将prevPageLabel和nextPageLabel设置为false

= LinkPager::widget([

'pagination' => $pages,

'nextPageLabel' => false,

'prevPageLabel' => false,

]); ?>

默认不显示首页也尾页,如果你需要,可以这样设置

= LinkPager::widget([

'pagination' => $pages,

'firstPageLabel' => '首页',

'lastPageLabel' => '尾页',

]); ?>

如果你的数据过少,不够2页,默认不显示分页,如果你需要,设置hideOnSinglePage=false即可

= LinkPager::widget([

'pagination' => $pages,

'hideOnSinglePage' => false,

]); ?>

默认显示的页码为10页,可以设置maxButtonCount为你想要展示的页数

= LinkPager::widget([

'pagination' => $pages,

'maxButtonCount' => 5,

]); ?>

有些人不喜欢默认的样式,想要分页带上自己的样式,可以设置options,不要忘了自行实现pre,next,disabled等样式

= LinkPager::widget([

'pagination' => $pages,

'options' => ['class' => 'm-pagination'],

]); ?>

接下来我们谈谈Pagination组件

默认的分页路由是下面这样子的,我们看看能做点什么

/controller/action?page=2&per-page=20

首先,我们是必须要指定总条数totalCount的,没这个参数,分页也是没办法实现的

$pages = new Pagination([

'totalCount' => $totalCount,

]);

默认分页的数量是20,你可以设置pageSize为你想要的

$pages = new Pagination([

'totalCount' => $totalCount,

'pageSize' => 5,

]);

从上面的分页路由我们可以看到,默认带的有每页的数量per-page 如果你不想显示该参数,设置pageSizeParam=false就好

$pages = new Pagination([

'totalCount' => $totalCount,

'pageSizeParam' => false,

]);

我们也可以看到,默认的页面取决于参数page,如果你想改变该参数为p,设置pageParam=p就好

$pages = new Pagination([

'totalCount' => $totalCount,

'pageParam' => 'p',

]);

如果你的分页存在于首页,相信你肯定想要/?p=1而不是/site/index?p=1,我们看看怎么隐藏掉路由

$pages = new Pagination([

'totalCount' => $totalCount,

'route' => false,

]);

可能你会发现分页类Pagination有一个bug,假如我们只有1页的数据,但是手动更改地址栏的page=20的时候,也会显示page=1的数据?当然,这在大部分接口API中就很让人厌烦。但是,这并非bug,而是一种友好的验证。设置validatePage=false即可避免掉该问题

$pages = new Pagination([

'totalCount' => $totalCount,

'validatePage' => false, ]);

最后,我们整点新花样,扩展下他这个自带的分页!别一看见扩展俩字下面的就直接不看了,只有自己学会扩展了,以后才能越来越强!怎么个扩展法呢?我们把分页组件改为上下页那种,具体参考下图做个对比吧

接下来我们就来看看右侧的效果具体是如何通过扩展LinkPager组件实现的。源码分享给大家,喜欢的拿去自己研究即可。

namespace frontend\components;

use yii\widgets\LinkPager;

use yii\helpers\Html;

class MLinkPager extends LinkPager

{

public $prevPageLabel = '';

public $nextPageLabel = '';

public $currentCountPageLabel = '第 {currentPage} 页 / 共 {countPage} 页';

public $currentCountPageClass = 'page-number';

public $hideOnSinglePage = false;

public function init () {

parent::init();

}

public function run () {

$pageCount = $this->pagination->getPageCount();

if ($pageCount < 2 && $this->hideOnSinglePage) {

return '';

}

$buttons = [];

$currentPage = $this->pagination->getPage();

// prev page

if ($this->prevPageLabel !== false) {

if (($page = $currentPage - 1) < 0) {

$page = 0;

}

$buttons[] = $this->renderPageButton($this->prevPageLabel, $page, $this->prevPageCssClass, $currentPage <= 0, false);

}

// current page / count page

if ($this->currentCountPageLabel !== false && $pageCount) {

$currentCountPageLabel = str_replace(['{currentPage}', '{countPage}'], [$currentPage+1, $pageCount], $this->currentCountPageLabel);

$buttons[] = Html::tag('span', $currentCountPageLabel, array('class' => $this->currentCountPageClass));

}

// next page

if ($this->nextPageLabel !== false) {

if (($page = $currentPage + 1) >= $pageCount - 1) {

$page = $pageCount - 1;

}

$buttons[] = $this->renderPageButton($this->nextPageLabel, $page, $this->nextPageCssClass, $currentPage >= $pageCount - 1, false);

}

return Html::tag('nav', implode("\n", $buttons), $this->options);

}

protected function renderPageButton($label, $page, $class, $disabled, $active)

{

$options = ['class' => empty($class) ? $this->pageCssClass : $class];

if ($active) {

Html::addCssClass($options, $this->activePageCssClass);

}

if ($disabled) {

return false;

}

$linkOptions = $this->linkOptions;

$linkOptions += $options;

$linkOptions['data-page'] = $page;

return Html::a($label, $this->pagination->createUrl($page), $linkOptions);

}

}

如此一来,我们调用MLinkPager实现分页效果像下面这样即可

use frontend\components\MLinkPager;

= MLinkPager::widget([

'pagination' => $pages,

]); ?>

当然,自己扩展的分页组建重在教大家如何去实现分页扩展,难免会有很多问题,如果你有好的意见或者方法,直接给我留言,咱们共同沟通交流。

php yii 控件分页,Yii2分页的使用及其扩展方法详解相关推荐

  1. android查询mysql并显示_Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解...

    本文实例讲述了Android操作SQLite数据库(增.删.改.查.分页等)及ListView显示数据的方法.分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识记录 ...

  2. 【HTML5】html5中列表、表格、表单控件、浮动框架及结构化标签知识详解大全

    一.列表 1.有序列表 <ol>有序列表 order list <li>列表项</li> <li>列表项</li> </ol> ...

  3. oracle分页排序查询,Oracle分页查询中排序与效率问题解决方法详解

    本文将结合作者近日工作中,在ORACLE数据库分页查询时,遇到一个小问题,为大家讲解如何解决Oracle分页查询中排序与效率问题. 原始未分页查询Sql代码如下: select ROWNUM rn, ...

  4. 【Unity-UGUI控件全面解析】| Dropdown 下拉菜单组件详解

  5. MVC3学习第十三章 佟掌柜第二弹——MVC3下利用陕北吴旗娃的分页控件实现数据分页...

    本章学习内容 1.了解陕北吴旗娃的Mvc分页控件 2.利用分页控件实现MVC3下的商品分页 3.利用分页控件实现MVC3下一个页面多个分页以及ajax分页效果 1.了解陕北吴旗娃的Mvc分页控件 在w ...

  6. repeater控件 php,asp.net Repeater控件的说明及详细介绍及使用方法

    Repeater 控件不具备内置的呈现功能,这表示用户必须通过创建模板为 Repeater 控件提供布局.当该页运行时,Repeater 控件依次通过数据源中的记录为每个记录呈现一个项. 他很简单,用 ...

  7. 使用控件时提示“未声明标识符“的解决方法

    使用控件时提示"未声明标识符"的解决方法 参考文章: (1)使用控件时提示"未声明标识符"的解决方法 (2)https://www.cnblogs.com/Ro ...

  8. android组件用法说明,Android第三方控件PhotoView使用方法详解

    Android第三方控件PhotoView使用方法详解 发布时间:2020-10-21 15:06:09 来源:脚本之家 阅读:74 作者:zhaihaohao1 PhotoView的简介: 这是一个 ...

  9. js设置控件的隐藏与显示的两种方法

    js设置控件的隐藏与显示的两种方法: js设置控件的隐藏与显示,设置控件style的display和visibility属性就可以了. 用JavaScript隐藏控件的方法有两种,分别是通过设置控件的 ...

最新文章

  1. saxon java_如何将Saxon设置为Java中的Xslt处理器?
  2. java 简单跳台阶和变态跳台阶
  3. 服务器php 不能运行框架,经验总结 PHP框架常见错误
  4. DISCUZ 使用 JQ做效果导致DIY失效的解决办法
  5. oracle tabs作用,Oracle 中 table 函数的应用浅析
  6. DDR3和eMMC区别
  7. 「浏览器插件」非常好用的JSON-View
  8. html css控制优先级,css权重及优先级问题_html/css_WEB-ITnose
  9. Mqtt协议IOS端移植3
  10. 理论基础 —— 查找 —— 平衡二叉树
  11. postfix所谓的监控功能只是利用sender_bcc而已
  12. Codeforces Round #318 [RussianCodeCup Thanks-Round] (Div. 1) B. Bear and Blocks 水题
  13. 火山PC后台操作第三方窗口案例
  14. mouseover 和 mouseenter的区别
  15. 云服务器网站logo,云服务器logo
  16. Draco - glTF模型压缩利器
  17. 来自百度,为什么要重构(Refactoring)
  18. “科目四”竟是民间杜撰出来的?
  19. Docker容器启动报WARNINGIPv4 forwarding
  20. 使用iMovie和Keynote制作App Preview

热门文章

  1. 算法复杂度为O(N) 的排序算法
  2. grub4dos和winsetupfromusb1.4
  3. BufferedInputStream学习笔记
  4. Nginx使用Expires增加浏览器缓存加速(转)
  5. MySQL 调用存储过程
  6. DBA用于查询当前数据库表格记录条数的脚本
  7. Windows Server 2003 群集配置测试
  8. ROS与navigation教程——基本导航调整指南
  9. 大众点评网2016校招试题选录
  10. 2019牛客暑期多校训练营(第一场) - B - Integration - 数学