


Detaillierte Erläuterung des Beispiels für einen benutzerdefinierten Laravel-Paging-Effekt
Die Paginierung von Laravel ist sehr praktisch und lässt sich tatsächlich ganz einfach erweitern. Lassen Sie uns unten ein Beispiel erstellen und die Methoden paginate() und simplePaginate() erweitern, um unseren benutzerdefinierten Paginierungsstil zu implementieren, z. B. die Anzeige von „vorherige Seite“ und „. Nächste Seite“ anstelle von „““ und „““. Wenn Sie die Erweiterungsmethode beherrschen, können Sie natürlich eine gewünschte Paginierung skrupellos erweitern, z. B. indem Sie zu einer bestimmten Seite springen und die Gesamtzahl der Datensätze in der Paginierung anzeigen. , der aktuell angezeigte Datensatzbereich usw. . .
5.1 und 5.2 sollten die gleiche Methode sein. Ich verwende hier Version 5.2. Aus der Dokumentation geht hervor, dass Paginator dem Abfrage-Builder und der simplePaginate-Methode von Eloquent entspricht, während LengthAwarePaginator der Paginate-Methode entspricht.
Dieser Artikel stellt hauptsächlich den benutzerdefinierten Paging-Implementierungscode im Detail vor. Interessierte Freunde können darauf verweisen.
Für die Laravel-Paginierung gibt es eine Paginierungsmethode, die sehr nützlich ist, aber auch Einschränkungen aufweist.
Also habe ich meine eigene Seite dafür geschrieben. Der spezifische Code lautet wie folgt
<?php namespace ...; use ...; /** * 自定义分页类,适合少数据的查询,多数据的时候不推荐 * Class CustomPaginate * @package App\Tools\Paginate */ class CustomPaginate { /** * 自定义数组分页 * @param $data = 返回结果 * @param $page * @param $limit * @return mixed */ public static function paginate($data, $page = 1, $limit = 10) { if (!is_numeric($page) || !is_numeric($limit)) { return false; } $count = count($data); $data = array_slice($data, ($page - 1) * $limit, $limit); return new LengthAwarePaginator($data, $count, $limit, $page); } /** * 参数解释 对外暴露的方法 * @param $data = array|collection 切记只支持这两种 * @param $page = 当前页 * @param $limit = 每一页展示几条 * @return array|false * 返回结果为数组 * 调用实例: CustomPaginate::paginateToArray($data, $request->page, $request->limit); */ public static function paginateToArray($data, $page = 1, $limit = 10) { $isValidate = self::validate($data, $page, $limit); //验证 if ($isValidate === false) { return false; } $res = self::paginate($data, $page, $limit)->toArray(); //分页数据转换为数组 //上一页 || 下一页 => path if ($res['prev_page_url'] != null) { $prev_page = $page - 1; $res['prev_page_url'] = Paginator::resolveCurrentPath() . "?page=" . $prev_page . "&limit=" . $limit; } if ($res['next_page_url'] != null) { $next_page = $page + 1; $res['next_page_url'] = Paginator::resolveCurrentPath() . "?page=" . $next_page . "&limit=" . $limit; } return $res; } /** * 验证参数是否合法 */ public static function validate(&$data, &$page = 1, &$limit = 10) { $page = empty($page) ? 1 : $page; $limit = empty($limit) ? 10 : $limit; if (!is_array($data) && !$data instanceof Collection) { return false;//"自定义分页方法只支持数组数据和集合数据"; } if (!is_numeric($page) || !is_numeric($limit)) { return false;//"page limit 参数只支持数字"; } if ($data instanceof Collection) { return $data = $data->toArray(); } return $data; } }
Verwandte Empfehlungen:
Laravel verwendet das Pagination-Plug-in, um benutzerdefiniertes Paging zu implementieren
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Beispiels für einen benutzerdefinierten Laravel-Paging-Effekt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Methode zum Abholen des Rücksendecode, wenn das Senden von Laravel -E -Mails fehlschlägt. Wenn Sie Laravel zur Entwicklung von Anwendungen verwenden, stellen Sie häufig Situationen auf, in denen Sie Überprüfungscodes senden müssen. Und in Wirklichkeit ...

Laravel -Zeitplan -Aufgabe Ausführen nicht reagierende Fehlerbehebung Bei Verwendung der Zeitplanung von Laravel -Zeitplänen werden viele Entwickler auf dieses Problem stoßen: Zeitplan: Run ...

Die Methode zum Umgang mit Laravels E -Mail -Versagen zum Senden von Verifizierungscode besteht darin, Laravel zu verwenden ...

So implementieren Sie die Tabellenfunktion von benutzerdefiniertem Klicken, um Daten in dcatadmin (laravel-admin) hinzuzufügen, wenn Sie DCAT verwenden ...

Die Auswirkungen des Austauschs von Redis -Verbindungen im Laravel -Framework und der Auswahl von Methoden bei Verwendung von Laravel -Framework und Redis können Entwickler auf ein Problem stoßen: Durch Konfiguration ...

Benutzerdefinierte Mieterdatenbankverbindung in Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis beim Erstellen von Multi-Mandanten-Anwendungen mit Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis, ...

Laraveleloquent-Modellab Abruf: Das Erhalten von Datenbankdaten Eloquentorm bietet eine prägnante und leicht verständliche Möglichkeit, die Datenbank zu bedienen. In diesem Artikel werden verschiedene eloquente Modellsuchtechniken im Detail eingeführt, um Daten aus der Datenbank effizient zu erhalten. 1. Holen Sie sich alle Aufzeichnungen. Verwenden Sie die Methode All (), um alle Datensätze in der Datenbanktabelle zu erhalten: UseApp \ Models \ post; $ posts = post :: all (); Dies wird eine Sammlung zurückgeben. Sie können mit der Foreach-Schleife oder anderen Sammelmethoden auf Daten zugreifen: foreach ($ postas $ post) {echo $ post->

Ein Problem der doppelten Klassendefinition während der Laravel -Datenbankmigration tritt auf. Bei Verwendung des Laravel -Frameworks für die Datenbankmigration können Entwickler "Klassen" verwendet ...
