PHP - Laravel - ビュー - blade ファイル名を取得


クラウディア 


1. 概要
2. 法則をもって変換
3. フレームワークで取得
4. 正式版
5. 参考サイト

1. 概要

 通常、「PHP」で、自身のファイル名を知るためには、「__FILE__」を使用するのですが、「Laravel」ではそれが通用しません。  「Lalavel blade __FILE__」で検索するとすぐに見つかります。  「Laravel」のドキュメントに
Note: Bladeビューの中では__DIR__や__FILE__を使わないでください。キャッシュされたコンパイル済みのビューのパスが返されるからです。
 と書かれておりますでな。  「__FILE__」で取得すると「generated::boJJf5MbNTiZXNHP」てな、わけのわからんことになります。

2. 法則をもって変換

 当初、下記のファイルおよびそのインクルードファイルの中で。

app/Providers/RouteServiceProvider.php
 下記を書く際。

Route::any('uri', function (){    return view('path/any.blade.php');});
 ある法則をもって、決めることにして、なんとかしのいできました。  しかし、コンテンツが増えていくと、例外が発生したりすることで、破綻しました。  困ったもんだ。

3. フレームワークで取得

 同じことを考える人がいるんですな。  やはり需要があるのでしょう。  参考サイトでやっているようです。  「ビューキャッシュを無効にする」って方向で調べていたのですが、そのうちに、わかっちゃいました。  「blade」ファイル名は(「Laravel Framework 10.48.29」の場合)。

vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php

    /**
     * Get the evaluated contents of the view.
     *
     * @param  string  $path
     * @param  array  $data
     * @return string
     */
    public function get($path, array $data = [])
    {
        $this->lastCompiled[] = $path;

        // If this given view has expired, which means it has simply been edited since
        // it was last compiled, we will re-compile the views so we can evaluate a
        // fresh copy of the view. We'll pass the compiler the path of the view.
        if ($this->compiler->isExpired($path)) {
            $this->compiler->compile($path);
        }

        // Once we have the path to the compiled file, we will evaluate the paths with
        // typical PHP just like any other templates. We also keep a stack of views
        // which have been rendered for right exception messages to be generated.
        $results = $this->evaluatePath($this->compiler->getCompiledPath($path), $data);

        array_pop($this->lastCompiled);

        return $results;
    }
 ここの、47行目、引数でわたってくる「$path」変数に、ファイル名がフルパスではいっています。  細かいことは省略しますが、これで、この変数を他へ使いまわせば、くっきり、ファイル名がわかることになります。  一時期、これをグローバル変数化して、使用していたりしました。  しかし、これフレームワークのソースですから、バージョンアップするとご破算になってしまったりします。

4. 正式版

 「Gemini」伍長のおかげで対処方法がわかりました。  「Laravel Framework 10.49.0」の場合。

app/Providers/AppServiceProvider.php

<?php
namespace App\Providers;

use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\View;

class AppServiceProvider extends ServiceProvider
{
    public function register(): void
    {
    }

    public function boot(): void
    {
    	View::composer('*', function ($view)
		{
    	});
    }
}
 「AppServiceProvider.php」の「boot()」内の「View::composer()」というのを記述してやれば。  「$view->getPath()」で、「.blade.php」のフルパスを取得できます。  ここで、グローバル変数に設定してやれば、他で使いまわしできるわけです。  ただし、注意しなければならないのは、「.blade.php」が、他の「.blade.php」をインクルードしている場合、インクルードしている分、「View::composer()」が呼ばれます。  なので、1リクエストで複数回呼ばれる可能性があるので、リクエストの初回がインクルードの元なので、「$view->getPath()」の値をセットする変数は、未設定のときのみ設定するような工夫が必要になります。

5. 参考サイト

 本ページは、下記のサイトおよび「Gemini」伍長を参考にさせていただきました。
「caching — Laravelビューキャッシュを無効にするにはどうすればよいですか?」← リンク切れになってしまいました

EaseUS
AbemaTV 無料体験