• yii2分页的基本使用及其配置详解


    作者:白狼 出处:http://www.manks.top/yii2_linkpager_pagination.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

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

    • 分页的使用,一步一步的教你怎么做
    • 分页类LinkPager和Pagination都可以自定义哪些属性

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

    1、controller action

    use yiidataPagination;
    $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 yiiwidgetsLinkPager;
    //循环展示数据
    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, 
    ]);

    ​[考虑目前国内网站大部分采集文章十分频繁,更有甚者不注明原文出处,原作者更希望看客们查看原文,以防有任何问题不能更新所有文章,避免误导!]

    继续阅读

  • 相关阅读:
    java之集合Collection 3个例子
    利用 ssh 的用户配置文件 config 管理 ssh 会话
    angularJS--apply() 、digest()和watch()方法
    37.创业团队不是天堂
    Android DiskLruCache 源码解析 硬盘缓存的绝佳方案
    sublime安装AngularJS插件
    angularJS 服务--$provide里factory、service方法
    angularJS--多个控制器之间的数据共享
    angularJS---自定义过滤器
    依赖反转
  • 原文地址:https://www.cnblogs.com/wwolf/p/5518741.html
Copyright © 2020-2023  润新知