Heim > Artikel > PHP-Framework > Benutzerdefiniertes Thinkphp-Paging
ThinkPHP5.1 verfügt über eine integrierte Paging-Implementierung. Es ist sehr einfach, den Daten eine Paging-Ausgabefunktion hinzuzufügen. Sie können die Paginierungsmethode direkt aufrufen, wenn Sie die Db-Klasse abfragen. In diesem Artikel wird erläutert, wie Sie Seitenstile in thinkphp anpassen.
thinkphp5.1 verfügt über eine sehr praktische Paging-Klasse. Sie können die Render-Methode verwenden, um den Paging-HTML-Code zu rendern.
Aber das „d11f5cfe936d235d653728cc5f168b4e>“ können manchmal den sich ändernden Anforderungen des Projekts nicht gerecht werden. Es ist notwendig, die Seitenanzeige selbst zu definieren, wie zum Beispiel
Homepage Vorherige Seite 1 2 3 ... 7 8 Nächste Seite Letzte Seite
Auf diese Weise wird im offiziellen Handbuch jedoch nicht erwähnt, wie der Seitenstil angepasst werden kann. Zuerst habe ich einfach den Paging-HTML-Text durch den vorherigen ersetzt Seite und die nächste Seite
Später habe ich herausgefunden, dass ich selbst eine Klasse definieren kann, um diese Anforderung zu erfüllen. Zuerst muss ich paginate.php im Konfigurationsverzeichnis erstellen, der Dateiinhalt ist
<?php return [ 'type'=>'app\index\pager\gcudPager'//自己的分页类可以随便放,只要命名空间写对 ];
Kopieren Sie dann das „Projektverzeichnis thinkphplibrarythinkpaginatordriverBootstrap.php“ an einen beliebigen Ort, ändern Sie den Namespace und ändern Sie den Typ von paginate.php in den entsprechenden Namespace. Beispielsweise habe ich die Datei wie oben in das „Projektverzeichnis applicationindexpagergcudPager.php“ kopiert Typ entspricht auch diesem Pfad und ändert dann den Namespace. Es wurde zu „appindexpager“ und der entsprechende Klassenname wurde in gcudPager geändert, sodass Sie die Paging-Form selbst definieren können
Ich habe die Implementierung von verfolgt die Homepage von der vorherigen Seite, kopiert ihren Code und ändert ihn leicht
/**首页按钮 * @param string $text * @return string */ protected function GetFirstButton($text='首页'){ if ($this->currentPage() <= 1) { return $this->getDisabledTextWrapper($text); } $url = $this->url(1); return $this->getPageLinkWrapper($url, $text); }
Die Logik ist sehr einfach: Sie besteht darin, die aktuelle Seitenzahl zu ermitteln und die Seitenzahlvariable manuell auf 1 zu setzen. Auf die gleiche Weise , Sie können den Code der nächsten Seite kopieren und auf die letzte Seite ändern
/**末页按钮 * @param string $text * @return string */ protected function GetLastButton($text='末页'){ if (!$this->hasMore) { return $this->getDisabledTextWrapper($text); } $url = $this->url($this->lastPage()); return $this->getPageLinkWrapper($url, $text); }
Andere vorherige Die nächste Seite besteht darin, den Text zu ändern. Es ist zu einfach, ihn nicht hinzuzufügen die Schaltflächen „Startseite“ und „Letzte Seite“
/** * 渲染分页html * @return mixed */ public function render() { if ($this->hasPages()) { if ($this->simple) { return sprintf( '<ul class="pager">%s %s</ul>', $this->getPreviousButton(), $this->getNextButton() ); } else { return sprintf( '<div class="page-captions">%s %s %s %s %s</div>', $this->GetFirstButton(), $this->getPreviousButton(), $this->getLinks(), $this->getNextButton(), $this->GetLastButton() ); } } }
Das ist es. Der aufrufende Teil muss überhaupt nicht geändert werden.
// +---------------------------------------------------------------------- namespace app\index\pager; use think\Paginator; class gcudPager extends Paginator { /**首页按钮 * @param string $text * @return string */ protected function GetFirstButton($text='首页'){ if ($this->currentPage() <= 1) { return $this->getDisabledTextWrapper($text); } $url = $this->url(1); return $this->getPageLinkWrapper($url, $text); } /** * 上一页按钮 * @param string $text * @return string */ protected function getPreviousButton($text = "上一页") { if ($this->currentPage() <= 1) { return $this->getDisabledTextWrapper($text); } $url = $this->url( $this->currentPage() - 1 ); return $this->getPageLinkWrapper($url, $text); } /**末页按钮 * @param string $text * @return string */ protected function GetLastButton($text='末页'){ if (!$this->hasMore) { return $this->getDisabledTextWrapper($text); } $url = $this->url($this->lastPage()); return $this->getPageLinkWrapper($url, $text); } /** * 下一页按钮 * @param string $text * @return string */ protected function getNextButton($text = '下一页') { if (!$this->hasMore) { return $this->getDisabledTextWrapper($text); } $url = $this->url($this->currentPage() + 1); return $this->getPageLinkWrapper($url, $text); } /** * 页码按钮 * @return string */ protected function getLinks() { if ($this->simple) { return ''; } $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( '<ul class="pager">%s %s</ul>', $this->getPreviousButton(), $this->getNextButton() ); } else { return sprintf( '<div class="page-captions">%s %s %s %s %s</div>', $this->GetFirstButton(), $this->getPreviousButton(), $this->getLinks(), $this->getNextButton(), $this->GetLastButton() ); } } } /** * 生成一个可点击的按钮 * * @param string $url * @param int $page * @return string */ protected function getAvailablePageWrapper($url, $page) { return '' . $page . ''; } /** * 生成一个禁用的按钮 * * @param string $text * @return string */ protected function getDisabledTextWrapper($text) { return '' . $text . ''; } /** * 生成一个激活的按钮 * * @param string $text * @return string */ protected function getActivePageWrapper($text) { return '' . $text . ''; } /** * 生成省略号按钮 * * @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 ($this->currentPage() == $page) { return $this->getActivePageWrapper($page); } return $this->getAvailablePageWrapper($url, $page); } }
Empfohlenes Tutorial: thinkphp-Tutorial
Das obige ist der detaillierte Inhalt vonBenutzerdefiniertes Thinkphp-Paging. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!