你需要将这个逻辑移到你的 ViewServiceProvider 而不是试图直接在配置文件中这样做,这是一个很大的不 .
所以我们要做的是
php artisan make:provider MyViewServiceProvider
这将导致文件存在于:
App\Providers\MyViewServiceProvider
现在我们要打开 config/app.php . 在此文件中找到现有的 ViewServiceProvider::class ,并将其替换为上面的命名空间路径 . 它应该看起来像这样:
//the old Illuminate\View\ViewServiceProvider::class
App\Providers\MyViewServiceProvider::class,
现在在 registerViewFinder() 函数内部,我们可以重载视图路径 .
namespace App\Providers;
use Illuminate\Support\Facades\Config;
public function registerViewFinder()
{
$this->app->bind('view.finder', function ($app) {
$custom_path = base_path('resources/views/layouts/' . Config::get('api.' . $this->app->request()->get('domain') . '.layout')
$paths = array_merge(
[$custom_path],
$app['config']['view.paths']
);
return new FileViewFinder($app['files'], $paths);
});
}
走这条路线将确保首先观察您的路径 . 如果在该路径中找不到该视图,则可以回退到 Laravel 的默认视图路径 .
Edit
重要的是要注意您的类需要扩展默认的ViewServiceProvider,并且必须声明其他2个函数,整个文件应如下所示:
namespace App\Providers;
use Illuminate\View\ViewServiceProvider;
use Illuminate\Support\Facades\Config;
class MyViewServiceProvider extends ViewServiceProvider
{
/**
* Bootstrap the application services.
*
* @return void
*/
public function boot()
{
parent::boot();
}
/**
* Register the application services.
*
* @return void
*/
public function register()
{
parent::register();
}
/**
* Register the view finder implementation.
*
* @return void
*/
public function registerViewFinder()
{
$this->app->bind('view.finder', function ($app) {
$custom_path = base_path('resources/views/layouts/' . Config::get('api.' . $this->app->request->get('domain') . '.layout')
$paths = array_merge(
[$custom_path],
$app['config']['view.paths']
);
return new FileViewFinder($app['files'], $paths);
});
}
}