Laravelで現在のURLを取得してメニューの色を変えたりハイライトする方法

Laravel・PHP豆知識・トラブル対策
スポンサーリンク

Laravelで、Bladeファイル上の処理だけで、カレントURLを取得し、メニューの色を変更できる方法を解説します。

コントローラーを使わないのでテンプレートにも使えますし、foreachを使った部分でもOK。

メニューの色を変えて、ユーザービリティを高めていきましょう。

スポンサーリンク

Laravelで現在のURLを取得してメニューの色を変えたりハイライトする方法

まずは基本編から。

次のリンクメニューを変更し、ユーザーがこのメニューにいるときには、色を変更するようにします。

次のようにコードに修正を加えます。

Bootstrapを使っていますが、もちろん、通常のクラス名を使っても大丈夫です。

分かりやすくクラス内のコードをまとめると、次のとおり。

{{url()->current() == route(‘ルート名’) ? ‘変更後のクラス名’ : ‘通常のクラス名’}}”>

url()->current() で、ユーザーが現在いるURLを指します。

その後、最初に【現在のURLになったときのクラス名】をいれ、コロンでくぎった後に【通常のクラス名】を指定します。

if文を使って書いた場合

上記のコードは三項演算子を使用して書きました。

もちろん、ifを使っても同じ動きをするコードを作れます。

その場合は、次のようになります。

ifの場合には、ルート名を{{}}で囲いません。

また、クラス名もクオテーションで囲いません。

foreach文を使っている場合

foreach文でも同じように使えます。

ルートと一緒に変数を引き渡す場合には、この変数も入れてあげます。

次のようになります。

foreach部分も、ユーザーが現在いる場所だけ色を変えることができます。

Laravel・PHP豆知識・トラブル対策

【無料プレゼント】

「LaravelでWebアプリをいちから作れるようになりたい!」

そんなLaravel初心者のあなたへ【Laravelの教科書】基礎編プレゼント中!
会員制フォーラムサイトを学習しながら作れます。

詳細はこちらをクリック

【個別サポート実施中】

「本ブログに記載の方法を試してみたけれど、うまくいかない」「コードを見てほしい」という方のために、有償でメールサポートいたします。以下のボタンをクリックして相談フォームにアクセスして下さい。

詳しく見る

Twitter始めました。
スポンサーリンク
40代からプログラミング!

コメント

タイトルとURLをコピーしました