先說明下我們本篇文章都要講哪些內容
第一步,我們來看看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組件
默認分頁類是下面這個樣子的
<?= LinkPager::widget([ 'pagination' => $pages, 'nextPageLabel' => '下一頁', 'prevPageLabel' => '上一頁', ]); ?>
<?= LinkPager::widget([ 'pagination' => $pages, 'nextPageLabel' => false, 'prevPageLabel' => false, ]); ?>
<?= LinkPager::widget([ 'pagination' => $pages, 'firstPageLabel' => '首頁', 'lastPageLabel' => '尾頁', ]); ?>
<?= LinkPager::widget([ 'pagination' => $pages, 'hideOnSinglePage' => false, ]); ?>
<?= LinkPager::widget([ 'pagination' => $pages, 'maxButtonCount' => 5, ]); ?>
<?= LinkPager::widget([ 'pagination' => $pages, 'options' => ['class' => 'm-pagination'], ]); ?>
接下來我們談談Pagination組件
默認的分頁路由是下面這樣子的,我們看看能做點什麼
/controller/action?page=2&per-page=20
$pages = new Pagination([ 'totalCount' => $totalCount, ]);
$pages = new Pagination([ 'totalCount' => $totalCount, 'pageSize' => 5, ]);
$pages = new Pagination([ 'totalCount' => $totalCount, 'pageSizeParam' => false, ]);
$pages = new Pagination([ 'totalCount' => $totalCount, 'pageParam' => 'p', ]);
$pages = new Pagination([ 'totalCount' => $totalCount, 'route' => false, ]);
$pages = new Pagination([ 'totalCount' => $totalCount, 'validatePage' => false, ]);
最後,我們整點新花樣,擴展下他這個自帶的分頁!別一看見擴展倆字下面的就直接不看了,只有自己學會擴展了,以後才能越來越強!怎麼個擴展法呢?我們把分頁組件改為上下頁那種,具體參考下圖做個對比吧
[考慮目前國內網站大部分采集文章十分頻繁,更有甚者不注明原文出處,原作者更希望看客們查看原文,以防有任何問題不能更新所有文章,避免誤導!]
繼續閱讀