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


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

    • 分页的使用,一步一步的教你怎么做
    • 分页类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, 
    ]);
    
     

    来源:https://www.cnblogs.com/wwolf/p/5518741.html

  • 相关阅读:
    windows本地文件搜索神器 Everything 为什么速度这么快?
    Electron构建跨平台应用
    「前端进阶」高性能渲染十万条数据(虚拟列表)
    Chrome开发者工具之JavaScript内存分析
    网页性能管理详解
    TCP-IP详解:滑动窗口(Sliding Window)
    滑动窗口
    流量控制(滑动窗口)和 拥塞控制(拥塞控制的工作过程)
    详解 Git 大文件存储(Git LFS)
    TCP流量控制
  • 原文地址:https://www.cnblogs.com/wuheng1991/p/8027892.html
Copyright © 2020-2023  润新知