Inhaltsverzeichnis
Laravels eigene Paging-Klasse
自定义视图
Heim PHP-Framework Laravel So implementieren Sie eine Paging-Funktion im benutzerdefinierten Stil in Laravel

So implementieren Sie eine Paging-Funktion im benutzerdefinierten Stil in Laravel

Apr 11, 2023 pm 03:06 PM

Mit der kontinuierlichen Weiterentwicklung des Laravel-Frameworks entscheiden sich mittlerweile immer mehr Webprojekte dafür. Natürlich entscheiden sich auch viele Entwickler dafür, Laravel für die Entwicklung ihrer eigenen Websites zu verwenden. In der täglichen Entwicklung besteht die übliche Vorgehensweise darin, zunächst nach Open-Source-Bibliotheken zu suchen oder selbst Komponenten zu schreiben. In diesem Artikel erfahren Sie, wie das geht Verwenden Sie es. Laravel verfügt über eine eigene Paging-Klasse, um benutzerdefiniertes Paging zu implementieren.

Laravels eigene Paging-Klasse

Das Laravel-Framework verfügt über eine Paging-Bibliothek, die sehr bequem zu verwenden ist. Im Controller verwenden wir im Allgemeinen die Methode paginate(), um Daten abzufragen und Paginierungsergebnisse zurückzugeben, während wir in der Blade-Vorlage direkt die Methode links() zum Rendern verwenden können Paginierungslinks. Schauen Sie sich den folgenden Code an: paginate() 方法来查询数据并返回分页结果,而在 Blade 模板中我们可以直接使用 links() 方法来渲染分页链接,看下面的代码:

// 在控制器中查询数据并返回分页结果
$data = DB::table('table_name')->paginate(15);

// 在 Blade 模板中通过 links() 方法渲染分页链接
{{ $data->links() }}
Nach dem Login kopieren

这样代码就完成了分页查询的工作,并且将分页链接渲染到了页面上。但是这样的链接样式是默认的,如果想要更改样式,我们需要自定义视图。

自定义视图

我们先来了解下 links() 方法,我们可以在 Blade 模板中输出一下 {{ $data->links() }} 的值,得到的结果是这样的:

<ul class="pagination">
    <li class="page-item disabled" aria-disabled="true" aria-label="&laquo; Previous">
        <span class="page-link" aria-hidden="true">&lsaquo;</span>
    </li>
    <li class="page-item active" aria-current="page"><span class="page-link">1</span></li>
    <li class="page-item"><a class="page-link" href="http://localhost?page=2">2</a></li>
    <li class="page-item"><a class="page-link" href="http://localhost?page=3">3</a></li>
    <li class="page-item"><a class="page-link" href="http://localhost?page=4">4</a></li>
    <li class="page-item"><a class="page-link" href="http://localhost?page=5">5</a></li>
    <li class="page-item">
        <a class="page-link" href="http://localhost?page=2" rel="next" aria-label="Next &raquo;">&rsaquo;</a>
    </li>
</ul>
Nach dem Login kopieren

我们发现,links() 方法默认渲染的分页链接是一个无序列表,每一项都是一个独立的 li 元素,其中 active 类表示当前页码,disabled 类表示不可用的页码。如果我们想要自定义分页链接的样式,就需要在视图文件中覆盖 Laravel 默认的链接渲染。

在 Laravel 中,可以使用 php artisan make:view 命令来生成视图文件,如下:

php artisan make:view pagination
Nach dem Login kopieren

这个命令将在 resources/views 目录下创建一个名为 pagination.blade.php 的文件。在该文件中写入如下代码:

@if ($paginator->hasPages())
    <nav>
        <ul class="pagination">
            {{-- Previous Page Link --}}
            @if ($paginator->onFirstPage())
                <li class="page-item disabled" aria-disabled="true" aria-label="@lang(&#39;pagination.previous&#39;)">
                    <span class="page-link" aria-hidden="true">&lsaquo;</span>
                </li>
            @else
                <li class="page-item">
                    <a class="page-link" href="{{ $paginator->previousPageUrl() }}" rel="prev" aria-label="@lang('pagination.previous')">&lsaquo;</a>
                </li>
            @endif

            {{-- Pagination Elements --}}
            @foreach ($elements as $element)
                {{-- "Three Dots" Separator --}}
                @if (is_string($element))
                    <li class="page-item disabled" aria-disabled="true"><span class="page-link">{{ $element }}</span></li>
                @endif

                {{-- Array Of Links --}}
                @if (is_array($element))
                    @foreach ($element as $page => $url)
                        @if ($page == $paginator->currentPage())
                            <li class="page-item active" aria-current="page"><span class="page-link">{{ $page }}</span></li>
                        @else
                            <li class="page-item"><a class="page-link" href="{{ $url }}">{{ $page }}</a></li>
                        @endif
                    @endforeach
                @endif
            @endforeach

            {{-- Next Page Link --}}
            @if ($paginator->hasMorePages())
                <li class="page-item">
                    <a class="page-link" href="{{ $paginator->nextPageUrl() }}" rel="next" aria-label="@lang('pagination.next')">&rsaquo;</a>
                </li>
            @else
                <li class="page-item disabled" aria-disabled="true" aria-label="@lang(&#39;pagination.next&#39;)">
                    <span class="page-link" aria-hidden="true">&rsaquo;</span>
                </li>
            @endif
        </ul>
    </nav>
@endif
Nach dem Login kopieren

这段代码是 Laravel 默认的分页视图代码,我们可以将其拷贝到 pagination.blade.php

<nav aria-label="Page navigation example">
  <ul class="pagination justify-content-center">
    @if ($paginator->onFirstPage())
        <li class="page-item disabled"><span class="page-link">上一页</span></li>
    @else
        <li class="page-item"><a class="page-link" href="{{ $paginator->previousPageUrl() }}">上一页</a></li>
    @endif

    @foreach ($elements as $element)
        @if (is_string($element))
            <li class="page-item disabled"><span class="page-link">{{ $element }}</span></li>
        @endif

        @if (is_array($element))
            @foreach ($element as $page => $url)
                @if ($page == $paginator->currentPage())
                    <li class="page-item active"><span class="page-link">{{ $page }}</span></li>
                @else
                    <li class="page-item"><a class="page-link" href="{{ $url }}">{{ $page }}</a></li>
                @endif
            @endforeach
        @endif
    @endforeach

    @if ($paginator->hasMorePages())
        <li class="page-item"><a class="page-link" href="{{ $paginator->nextPageUrl() }}">下一页</a></li>
    @else
        <li class="page-item disabled"><span class="page-link">下一页</span></li>
    @endif
  </ul>
</nav>
Nach dem Login kopieren
Auf diese Weise vervollständigt der Code die Arbeit der Paginierungsabfrage und rendert den Paginierungslink zur Seite. Dieser Linkstil ist jedoch der Standard. Wenn wir den Stil ändern möchten, müssen wir die Ansicht anpassen.

Benutzerdefinierte Ansicht

Lassen Sie uns zunächst die Methode links() verstehen. Wir können sie in der Blade-Vorlage {{ $data->links() }} ausgeben , das Ergebnis ist wie folgt:

rrreee

Wir haben festgestellt, dass der von der Methode links() standardmäßig gerenderte Paging-Link eine ungeordnete Liste ist und jedes Element ein unabhängiger liist >-Element, wobei die Klasse active die aktuelle Seitenzahl und die Klasse disabled eine nicht verfügbare Seitenzahl darstellt. Wenn wir den Stil von Paginierungslinks anpassen möchten, müssen wir Laravels Standard-Link-Rendering in der Ansichtsdatei überschreiben.

In Laravel können Sie den Befehl php artisan make:view verwenden, um eine Ansichtsdatei wie folgt zu generieren:

rrreee

Dieser Befehl erstellt einen Namen im Verzeichnis resources/views code>-Verzeichnis Die Datei ist <code>pagination.blade.php. Schreiben Sie den folgenden Code in diese Datei:

rrreee

Dieser Code ist Laravels Standard-Paginierungsansichtscode. Wir können ihn in die Datei pagination.blade.php kopieren und dann anpassen. 🎜🎜Benutzerdefinierter Stil🎜🎜Der benutzerdefinierte Stil hängt von den eigenen Vorlieben des Entwicklers ab. Beispielsweise können wir den Paging-Link in einen Schaltflächenstil ändern: 🎜rrreee🎜Da es normalerweise nicht zu viele Paging-Links und die Paging-Link-Stile verschiedener Seiten gibt Es kann anders sein, daher bieten wir hier nur eine einfache Änderungsmethode an, die Entwickler flexibel an ihre eigenen Bedürfnisse anpassen können. 🎜🎜Zusammenfassung🎜🎜Durch die Einleitung dieses Artikels haben wir erfahren, wie die mit dem Laravel-Framework gelieferte Paging-Klasse implementiert wird und wie der Stil von Paging-Links durch benutzerdefinierte Ansichten geändert wird. Natürlich ist diese Anpassung nicht auf Paginierungsstile beschränkt, Entwickler können sie auch auf verschiedene andere Layoutstile anwenden. 🎜🎜In der tatsächlichen Entwicklung können exzellente Entwickler jederzeit das Potenzial des Frameworks entdecken und es entsprechend ihren eigenen Bedürfnissen optimieren. Dies ist eine der Technologien, die beherrscht werden müssen, um ein exzellenter Entwickler zu werden. Ich hoffe, dass dieser Artikel für alle hilfreich sein kann, und ich hoffe auch, dass jeder ein tieferes Verständnis und eine bessere Anwendung des Laravel-Frameworks erlangen kann. 🎜

Das obige ist der detaillierte Inhalt vonSo implementieren Sie eine Paging-Funktion im benutzerdefinierten Stil in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was ist besser, Django oder Laravel? Was ist besser, Django oder Laravel? Mar 28, 2025 am 10:41 AM

Sowohl Django als auch Laravel sind Full-Stack-Frameworks. Django eignet sich für Python -Entwickler und komplexe Geschäftslogik, während Laravel für PHP -Entwickler und elegante Syntax geeignet ist. 1.Django basiert auf Python und folgt der "batteriebetriebenen" Philosophie, die für schnelle Entwicklung und hohe Parallelität geeignet ist. 2. Laravel basiert auf PHP, der die Entwicklererfahrung betont und für kleine bis mittlere Projekte geeignet ist.

Laravel und das Backend: Logik der Webanwendungen mit Strom versorgen Laravel und das Backend: Logik der Webanwendungen mit Strom versorgen Apr 11, 2025 am 11:29 AM

Wie spielt Laravel eine Rolle in der Backend -Logik? Es vereinfacht und verbessert die Backend -Entwicklung durch Routing -Systeme, eloquentorm, Authentifizierung und Autorisierung, Ereignis und Zuhörer sowie Leistungsoptimierung. 1. Das Routing -System ermöglicht die Definition der URL -Struktur und die Anforderungsverarbeitungslogik. 2.Loquentorm vereinfacht die Datenbankinteraktion. 3. Das Authentifizierungs- und Autorisierungssystem ist für die Benutzerverwaltung geeignet. 4. Die Ereignis und der Hörer implementieren locker gekoppelte Codestruktur. 5. Leistungsoptimierung verbessert die Anwendungseffizienz durch Zwischenspeicherung und Warteschlange.

Welches ist besser PHP oder Laravel? Welches ist besser PHP oder Laravel? Mar 27, 2025 pm 05:31 PM

PHP und Laravel sind nicht direkt vergleichbar, da Laravel ein PHP-basierter Framework ist. 1.PHP ist für kleine Projekte oder schnelle Prototypen geeignet, da es einfach und direkt ist. 2. Laravel ist für große Projekte oder effiziente Entwicklung geeignet, da es umfangreiche Funktionen und Werkzeuge bietet, aber eine steile Lernkurve aufweist und möglicherweise nicht so gut ist wie reines PHP.

Ist Laravel ein Frontend oder ein Backend? Ist Laravel ein Frontend oder ein Backend? Mar 27, 2025 pm 05:31 PM

LaravelisabackendFrameworkBuiltonPhp, entworfene WebApplicationDevelopment.itfocuseSonserver-Sidelogic, DatabaSemanagement und Applicationsstruktur und CanBeintegratedWithFrontendTechnologies-ähnlich.

Warum ist Laravel so beliebt? Warum ist Laravel so beliebt? Apr 02, 2025 pm 02:16 PM

Die Popularität von Laravel umfasst seinen vereinfachten Entwicklungsprozess, eine angenehme Entwicklungsumgebung und umfangreiche Merkmale. 1) Es absorbiert die Designphilosophie von RubyonRails und kombiniert die Flexibilität von PHP. 2) Bereitstellung von Werkzeugen wie eloquentorm, Blade Template Engine usw. zur Verbesserung der Entwicklungseffizienz. 3) Sein MVC -Architektur- und Abhängigkeitsinjektionsmechanismus macht den Code modularer und prüfbarer. 4) Bietet leistungsstarke Debugging -Tools und Leistungsoptimierungsmethoden wie Caching -Systeme und Best Practices.

Laravel (PHP) gegen Python: Entwicklungsumgebungen und Ökosysteme Laravel (PHP) gegen Python: Entwicklungsumgebungen und Ökosysteme Apr 12, 2025 am 12:10 AM

Der Vergleich zwischen Laravel und Python in der Entwicklungsumgebung und dem Ökosystem ist wie folgt: 1. Die Entwicklungsumgebung von Laravel ist einfach, nur PHP und Komponist sind erforderlich. Es bietet eine umfassende Auswahl an Erweiterungspaketen wie Laravelforge, aber die Wartung des Erweiterungspakets ist möglicherweise nicht rechtzeitig. 2. Die Entwicklungsumgebung von Python ist ebenfalls einfach, nur Python und PIP sind erforderlich. Das Ökosystem ist riesig und deckt mehrere Felder ab, aber das Versions- und Abhängigkeitsmanagement kann komplex sein.

Laravels Vielseitigkeit: Von einfachen Standorten zu komplexen Systemen Laravels Vielseitigkeit: Von einfachen Standorten zu komplexen Systemen Apr 13, 2025 am 12:13 AM

Das Laravel -Entwicklungsprojekt wurde aufgrund seiner Flexibilität und Kraft ausgewählt, um den Bedürfnissen unterschiedlicher Größen und Komplexität zu entsprechen. Laravel bietet Routing-System, eloquentorm, Artisan Command Line und andere Funktionen und unterstützt die Entwicklung von einfachen Blogs bis hin zu komplexen Systemen auf Unternehmensebene.

Laravels Hauptfunktion: Backend -Entwicklung Laravels Hauptfunktion: Backend -Entwicklung Apr 15, 2025 am 12:14 AM

Zu den Kernfunktionen von Laravel in der Back-End-Entwicklung gehören Routing-System, eloquentorm, Migrationsfunktion, Cache-System und Warteschlangensystem. 1. Das Routing -System vereinfacht die URL -Zuordnung und verbessert die Codeorganisation und die Wartung. 2.Loquentorm bietet objektorientierte Datenoperationen zur Verbesserung der Entwicklungseffizienz. 3. Die Migrationsfunktion verwaltet die Datenbankstruktur durch Versionskontrolle, um eine Konsistenz zu gewährleisten. 4. Das Cache -System reduziert Datenbankabfragen und verbessert die Reaktionsgeschwindigkeit. 5. Das Warteschlangensystem verarbeitet effektiv große Daten, vermeiden Sie die Blockierung von Benutzeranfragen und verbessern die Gesamtleistung.

See all articles