Laravelでカスタムスタイルのページング機能を実装する方法
Laravel フレームワークの継続的な開発により、ますます多くの Web プロジェクトが Laravel フレームワークを選択するようになり、もちろん、多くの開発者が独自の Web サイトの開発に Laravel を使用することを選択しています。日常の開発では、機能を実装するために、最初にオープン ソース ライブラリを探すか、コンポーネントを自分で作成するのが通常のアプローチです。これまでの経験や概要がインターネット上にたくさんあります。この記事はそのうちの 1 つです。その方法を説明します。 Laravel には、カスタム スタイルのページングを実装するための独自のページング クラスが付属しています。
Laravel 独自のページング クラス
Laravel フレームワークには、非常に使いやすいページング ライブラリが付属しています。コントローラーでは通常、paginate()
メソッドを使用してデータをクエリし、ページネーションの結果を返しますが、Blade テンプレートでは、links()
メソッドを直接使用してページネーション リンクをレンダリングできます。については、次のコードを参照してください。
// 在控制器中查询数据并返回分页结果 $data = DB::table('table_name')->paginate(15); // 在 Blade 模板中通过 links() 方法渲染分页链接 {{ $data->links() }}
このようにして、コードはページング クエリを完了し、ページへのページング リンクをレンダリングします。ただし、このリンク スタイルはデフォルトなので、スタイルを変更したい場合はビューをカスタマイズする必要があります。
カスタム ビュー
まず links()
メソッドを理解しましょう。これは Blade テンプレートに出力できます{{ $data->links () }}
、結果は次のとおりです:
<ul class="pagination"> <li class="page-item disabled" aria-disabled="true" aria-label="« Previous"> <span class="page-link" aria-hidden="true">‹</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 »">›</a> </li> </ul>
links()
メソッドによってレンダリングされるページング リンクは、デフォルトでは順序なしリストであり、それぞれの項目は独立した li
要素。 active
クラスは現在のページ番号を表し、disabled
クラスは使用できないページ番号を表します。ページネーションリンクのスタイルをカスタマイズしたい場合は、ビューファイルでLaravelのデフォルトのリンクレンダリングをオーバーライドする必要があります。
Laravel では、次のように php 職人の make:view
コマンドを使用してビュー ファイルを生成できます。
php artisan make:view pagination
このコマンドは 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('pagination.previous')"> <span class="page-link" aria-hidden="true">‹</span> </li> @else <li class="page-item"> <a class="page-link" href="{{ $paginator->previousPageUrl() }}" rel="prev" aria-label="@lang('pagination.previous')">‹</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')">›</a> </li> @else <li class="page-item disabled" aria-disabled="true" aria-label="@lang('pagination.next')"> <span class="page-link" aria-hidden="true">›</span> </li> @endif </ul> </nav> @endif
このコードは 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>
ページング リンクは通常、そこにあります。あまり多くはありませんし、ページごとにページング リンクのスタイルも異なる可能性があるため、ここでは簡単な変更方法のみを提供します。開発者は独自のニーズに応じて柔軟に調整できます。
概要
この記事の導入部を通じて、Laravel フレームワークに付属するページング クラスがどのように実装されるか、またカスタム ビューを通じてページング リンクのスタイルを変更する方法を学びました。もちろん、このカスタマイズはページネーション スタイルに限定されず、開発者は他のさまざまなレイアウト スタイルにも適用できます。
優れた開発者は、実際の開発において、常にフレームワークの可能性を発見し、自分のニーズに合わせて最適化することができ、優れた開発者になるために習得しなければならない技術の一つです。この記事が皆さんのお役に立てば幸いです。また、皆さんが Laravel フレームワークをより深く理解して応用できることを願っています。
以上がLaravelでカスタムスタイルのページング機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









DjangoとLaravelはどちらもフルスタックのフレームワークです。 DjangoはPython開発者や複雑なビジネスロジックに適していますが、LaravelはPHP開発者とエレガントな構文に適しています。 1.DjangoはPythonに基づいており、迅速な発展と高い並行性に適した「バッテリーコンプリート」哲学に従います。 2. LaravelはPHPに基づいており、開発者エクスペリエンスを強調しており、小規模から中規模のプロジェクトに適しています。

Laravelはバックエンドロジックでどのように役割を果たしますか?ルーティングシステム、Eloquentorm、認証と承認、イベントとリスナー、パフォーマンスの最適化を通じてバックエンド開発を簡素化および強化します。 1.ルーティングシステムにより、URL構造の定義とリクエスト処理ロジックが可能になります。 2.Eloquentormは、データベースの相互作用を簡素化します。 3.認証および承認システムは、ユーザー管理に便利です。 4.イベントとリスナーは、ゆるく結合したコード構造を実装します。 5.パフォーマンスの最適化により、キャッシュとキューイングを通じてアプリケーションの効率が向上します。

LaravelはPHPベースのフレームワークであるため、PHPとLaravelは直接匹敵するものではありません。 1.PHPは、シンプルで直接的であるため、小規模プロジェクトや迅速なプロトタイピングに適しています。 2。LARAVELは、豊富な機能とツールを提供するため、大規模なプロジェクトや効率的な開発に適していますが、急な学習曲線があり、純粋なPHPほど良くない場合があります。

laravelisabackendframeworkbuiltonphp、designforwebapplicationdevelopment.itfocusonserver-sidelogic、databasemanagement、およびapplicationStructure、およびbueithedendtechnologiesvue.jsorreactforfull-stackdevelymentと統合されていること。

Laravelの人気には、単純化された開発プロセスが含まれ、快適な開発環境を提供し、豊富な機能が提供されます。 1)Rubyonrailsの設計哲学を吸収し、PHPの柔軟性を組み合わせています。 2)Eloquentorm、Bladeテンプレートエンジンなどのツールを提供して、開発効率を向上させます。 3)そのMVCアーキテクチャと依存関係噴射メカニズムにより、コードがよりモジュール化され、テスト可能になります。 4)キャッシュシステムやベストプラクティスなどの強力なデバッグツールとパフォーマンス最適化方法を提供します。

開発環境とエコシステムにおけるLaravelとPythonの比較は次のとおりです。1。Laravelの開発環境は簡単で、PHPと作曲家のみが必要です。 Laravelforgeなどの豊富な範囲の拡張パッケージを提供しますが、拡張パッケージのメンテナンスはタイムリーではない場合があります。 2。Pythonの開発環境もシンプルで、PythonとPIPのみが必要です。エコシステムは巨大で複数のフィールドをカバーしていますが、バージョンと依存関係の管理は複雑な場合があります。

Laravel Developmentプロジェクトは、さまざまなサイズと複雑さのニーズに合う柔軟性とパワーのために選択されました。 Laravelは、ルーティングシステム、Eloquentorm、Artisan Command Lineおよびその他の機能を提供し、簡単なブログから複雑なエンタープライズレベルのシステムへの開発をサポートしています。

バックエンド開発におけるLaravelのコア機能には、ルーティングシステム、Eloquentorm、移行機能、キャッシュシステム、キューシステムが含まれます。 1.ルーティングシステムは、URLマッピングを簡素化し、コードの組織とメンテナンスを改善します。 2.Eloquentormは、開発効率を改善するためにオブジェクト指向のデータ操作を提供します。 3.移行関数は、バージョン制御を介してデータベース構造を管理して、一貫性を確保します。 4.キャッシュシステムは、データベースクエリを削減し、応答速度を向上させます。 5.キューシステムは、大規模なデータを効果的に処理し、ユーザー要求のブロックを避け、全体的なパフォーマンスを改善します。
