日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > php >内容正文

php

Thinkphp5 自定义分页类

發(fā)布時(shí)間:2025/3/21 php 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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)容還不錯,歡迎將生活随笔推薦給好友。