這篇文章給大家分享的是有關(guān)Yii2分頁(yè)類(lèi)怎么用的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
10年的玉山網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都營(yíng)銷(xiāo)網(wǎng)站建設(shè)的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整玉山建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)建站從事“玉山網(wǎng)站設(shè)計(jì)”,“玉山網(wǎng)站推廣”以來(lái),每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。第一步,我們來(lái)看看yii2自帶的分頁(yè)類(lèi)該如何去使用?
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; //循環(huán)展示數(shù)據(jù) foreach ($models as $model) { // ...... } //顯示分頁(yè)頁(yè)碼 echo LinkPager::widget([ 'pagination' => $pages, ])
代碼基本上可以完全拷貝,修改部分?jǐn)?shù)據(jù)即可,相信大多數(shù)人都是看得懂的。
我們接下來(lái)看第二步,自帶的分頁(yè)類(lèi)都可以定義哪些屬性
首先我們說(shuō)說(shuō)LinkPager組件
.pagination參數(shù)必填,這個(gè)是我們Pagination類(lèi)的實(shí)例
默認(rèn)分頁(yè)類(lèi)是下面這個(gè)樣子的
.上下頁(yè)按鈕以及10個(gè)按鈕
首先,我們把上下頁(yè)的按鈕修改成中文
= LinkPager::widget([ 'pagination' => $pages, 'nextPageLabel' => '下一頁(yè)', 'prevPageLabel' => '上一頁(yè)', ]); ?>
如果你不想要顯示上下頁(yè),可以將prevPageLabel和nextPageLabel設(shè)置為false
= LinkPager::widget([ 'pagination' => $pages, 'nextPageLabel' => false, 'prevPageLabel' => false, ]); ?>
默認(rèn)不顯示首頁(yè)也尾頁(yè),如果你需要,可以這樣設(shè)置
= LinkPager::widget([ 'pagination' => $pages, 'firstPageLabel' => '首頁(yè)', 'lastPageLabel' => '尾頁(yè)', ]); ?>
如果你的數(shù)據(jù)過(guò)少,不夠2頁(yè),默認(rèn)不顯示分頁(yè),如果你需要,設(shè)置hideOnSinglePage=false即可
= LinkPager::widget([ 'pagination' => $pages, 'hideOnSinglePage' => false, ]); ?>
默認(rèn)顯示的頁(yè)碼為10頁(yè),可以設(shè)置maxButtonCount為你想要展示的頁(yè)數(shù)
= LinkPager::widget([ 'pagination' => $pages, 'maxButtonCount' => 5, ]); ?>
有些人不喜歡默認(rèn)的樣式,想要分頁(yè)帶上自己的樣式,可以設(shè)置options,不要忘了自行實(shí)現(xiàn)pre,next,disabled等樣式
= LinkPager::widget([ 'pagination' => $pages, 'options' => ['class' => 'm-pagination'], ]); ?>
接下來(lái)我們談?wù)凱agination組件
默認(rèn)的分頁(yè)路由是下面這樣子的,我們看看能做點(diǎn)什么
/controller/action?page=2&per-page=20
首先,我們是必須要指定總條數(shù)totalCount的,沒(méi)這個(gè)參數(shù),分頁(yè)也是沒(méi)辦法實(shí)現(xiàn)的
$pages = new Pagination([ 'totalCount' => $totalCount, ]);
默認(rèn)分頁(yè)的數(shù)量是20,你可以設(shè)置pageSize為你想要的
$pages = new Pagination([ 'totalCount' => $totalCount, 'pageSize' => 5, ]);
從上面的分頁(yè)路由我們可以看到,默認(rèn)帶的有每頁(yè)的數(shù)量per-page 如果你不想顯示該參數(shù),設(shè)置pageSizeParam=false就好
$pages = new Pagination([ 'totalCount' => $totalCount, 'pageSizeParam' => false, ]);
我們也可以看到,默認(rèn)的頁(yè)面取決于參數(shù)page,如果你想改變?cè)搮?shù)為p,設(shè)置pageParam=p就好
$pages = new Pagination([ 'totalCount' => $totalCount, 'pageParam' => 'p', ]);
如果你的分頁(yè)存在于首頁(yè),相信你肯定想要/?p=1而不是/site/index?p=1,我們看看怎么隱藏掉路由
$pages = new Pagination([ 'totalCount' => $totalCount, 'route' => false, ]);
可能你會(huì)發(fā)現(xiàn)分頁(yè)類(lèi)Pagination有一個(gè)bug,假如我們只有1頁(yè)的數(shù)據(jù),但是手動(dòng)更改地址欄的page=20的時(shí)候,也會(huì)顯示page=1的數(shù)據(jù)?當(dāng)然,這在大部分接口API中就很讓人厭煩。但是,這并非bug,而是一種友好的驗(yàn)證。設(shè)置validatePage=false即可避免掉該問(wèn)題
$pages = new Pagination([ 'totalCount' => $totalCount, 'validatePage' => false, ]);
最后,我們整點(diǎn)新花樣,擴(kuò)展下他這個(gè)自帶的分頁(yè)!別一看見(jiàn)擴(kuò)展倆字下面的就直接不看了,只有自己學(xué)會(huì)擴(kuò)展了,以后才能越來(lái)越強(qiáng)!怎么個(gè)擴(kuò)展法呢?我們把分頁(yè)組件改為上下頁(yè)那種,具體參考下圖做個(gè)對(duì)比吧
接下來(lái)我們就來(lái)看看右側(cè)的效果具體是如何通過(guò)擴(kuò)展LinkPager組件實(shí)現(xiàn)的。源碼分享給大家,喜歡的拿去自己研究即可。
'; public $nextPageLabel = ''; public $currentCountPageLabel = '第 {currentPage} 頁(yè) / 共 {countPage} 頁(yè)'; 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); } }
如此一來(lái),我們調(diào)用MLinkPager實(shí)現(xiàn)分頁(yè)效果像下面這樣即可
use frontend\components\MLinkPager; = MLinkPager::widget([ 'pagination' => $pages, ]); ?>
感謝各位的閱讀!關(guān)于“Yii2分頁(yè)類(lèi)怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!