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部分も、ユーザーが現在いる場所だけ色を変えることができます。

コメント

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