生活随笔
收集整理的這篇文章主要介紹了
Thinkphp5 自定义分页类
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1.在extend\目錄下創(chuàng)建page目錄,在page目錄中創(chuàng)建Page.php文件,將以下代碼放入文件中
<?php
namespace page;
use think\Paginator;
class Page extends Paginator
{
//首頁
protected function home() {if ($this->currentPage() > 1) {return "<a href='" . $this->url(1) . "' title='首頁'>首頁</a>";} else {return "<p>首頁</p>";}
}//上一頁
protected function prev() {if ($this->currentPage() > 1) {return "<a href='" . $this->url($this->currentPage - 1) . "' title='上一頁'>上一頁</a>";} else {return "<p>上一頁</p>";}
}//下一頁
protected function next() {if ($this->hasMore) {return "<a href='" . $this->url($this->currentPage + 1) . "' title='下一頁'>下一頁</a>";} else {return"<p>下一頁</p>";}
}//尾頁
protected function last() {if ($this->hasMore) {return "<a href='" . $this->url($this->lastPage) . "' title='尾頁'>尾頁</a>";} else {return "<p>尾頁</p>";}
}//統(tǒng)計(jì)信息
protected function info(){return "<p class='pageRemark'>共<b>" . $this->lastPage ."</b>頁<b>" . $this->total . "</b>條數(shù)據(jù)</p>";
}/*** 頁碼按鈕* @return string*/
protected function getLinks()
{$block = ['first' => null,'slider' => null,'last' => null];$side = 3;$window = $side * 2;if ($this->lastPage < $window + 6) {$block['first'] = $this->getUrlRange(1, $this->lastPage);} elseif ($this->currentPage <= $window) {$block['first'] = $this->getUrlRange(1, $window + 2);$block['last'] = $this->getUrlRange($this->lastPage - 1, $this->lastPage);} elseif ($this->currentPage > ($this->lastPage - $window)) {$block['first'] = $this->getUrlRange(1, 2);$block['last'] = $this->getUrlRange($this->lastPage - ($window + 2), $this->lastPage);} else {$block['first'] = $this->getUrlRange(1, 2);$block['slider'] = $this->getUrlRange($this->currentPage - $side, $this->currentPage + $side);$block['last'] = $this->getUrlRange($this->lastPage - 1, $this->lastPage);}$html = '';if (is_array($block['first'])) {$html .= $this->getUrlLinks($block['first']);}if (is_array($block['slider'])) {$html .= $this->getDots();$html .= $this->getUrlLinks($block['slider']);}if (is_array($block['last'])) {$html .= $this->getDots();$html .= $this->getUrlLinks($block['last']);}return $html;
}/*** 渲染分頁html* @return mixed*/
public function render()
{if ($this->hasPages()) {if ($this->simple) {return sprintf('%s<div class="pagination">%s %s %s</div>',$this->css(),$this->prev(),$this->getLinks(),$this->next());} else {return sprintf('%s<div class="pagination">%s %s %s %s %s %s</div>',$this->css(),$this->home(),$this->prev(),$this->getLinks(),$this->next(),$this->last(),$this->info());}}
}/*** 生成一個(gè)可點(diǎn)擊的按鈕** @param string $url* @param int $page* @return string*/
protected function getAvailablePageWrapper($url, $page)
{return '<a href="' . htmlentities($url) . '" title="第"'. $page .'"頁" >' . $page . '</a>';
}/*** 生成一個(gè)禁用的按鈕** @param string $text* @return string*/
protected function getDisabledTextWrapper($text)
{return '<p class="pageEllipsis">' . $text . '</p>';
}/*** 生成一個(gè)激活的按鈕** @param string $text* @return string*/
protected function getActivePageWrapper($text)
{return '<a href="" class="cur">' . $text . '</a>';
}/*** 生成省略號按鈕** @return string*/
protected function getDots()
{return $this->getDisabledTextWrapper('...');
}/*** 批量生成頁碼按鈕.** @param array $urls* @return string*/
protected function getUrlLinks(array $urls)
{$html = '';foreach ($urls as $page => $url) {$html .= $this->getPageLinkWrapper($url, $page);}return $html;
}/*** 生成普通頁碼按鈕** @param string $url* @param int $page* @return string*/
protected function getPageLinkWrapper($url, $page)
{if ($page == $this->currentPage()) {return $this->getActivePageWrapper($page);}return $this->getAvailablePageWrapper($url, $page);
}/*** 分頁樣式*/
protected function css(){return ' <style type="text/css">.pagination p{margin:0;cursor:pointer}.pagination{height:40px;padding:20px 0px;}.pagination a{display:block;float:left;margin-right:10px;padding:2px 12px;height:24px;border:1px #cccccc solid;background:#fff;text-decoration:none;color:#808080;font-size:12px;line-height:24px;}.pagination a:hover{color:#077ee3;background: white;border:1px #077ee3 solid;}.pagination a.cur{border:none;background:#077ee3;color:#fff;}.pagination p{float:left;padding:2px 12px;font-size:12px;height:24px;line-height:24px;color:#bbb;border:1px #ccc solid;background:#fcfcfc;margin-right:8px;}.pagination p.pageRemark{border-style:none;background:none;margin-right:0px;padding:4px 0px;color:#666;}.pagination p.pageRemark b{color:red;}.pagination p.pageEllipsis{border-style:none;background:none;padding:4px 0px;color:#808080;}.dates li {font-size: 14px;margin:20px 0}.dates li span{float:right}</style>';
}
}
2.修改配置文件即可
//分頁配置
'paginate' => [
'type' => 'page\Page',//分頁類
'var_page' => 'page',
'list_rows' => 15,
],
分頁樣式為:
注:1)可以在代碼中修改CSS部分代碼,能修改一些顏色之類的樣式
2)如果開啟了TP5的簡潔分頁,只會顯示上一頁、下一頁兩個(gè)按鈕
原文地址:http://www.thinkphp.cn/topic/50858.html
轉(zhuǎn)載于:https://blog.51cto.com/pilipala/2130510
總結(jié)
以上是生活随笔為你收集整理的Thinkphp5 自定义分页类的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。