在开发过程中, 不时会遇到某些项目需要使用两套模板
如 PC 端和 Mobile 端使用不同的模板文件, 以达到最佳的用户体验
遇到这种情况我们应该如何配置 Laravel 的模板文件呢?
1. 安装 whichbrowser/parser 传送门: WhichBrowser/Parser-PHP
用于判断 PC 或 Mobile 设备, 按需加载不同的模板
composer require whichbrowser/parser
2. 使用 artisan 命令新建一个 Middleware(中间件)
执行后会在 app/Http/Middleware 目录生成中间件文件
php artisan make:middleware Template
3. 编辑 Template.php 文件
class Template
{
protected $except = [];
public function handle($request, Closure $next)
{
$result = new WhichBrowser\Parser(getallheaders());
// 如果是桌面类型, 返回 true
$isDesktop = $result->isType(‘desktop’);
if ($isDesktop) {
// 加载 pc 端的模板文件
$path = resource_path(‘views/pc/’);
} else {
// 加载 mobile 端的模板文件
$path = resource_path(‘views/mobile/’);
}
// 获取视图查找器实例
$view = app(‘view’)->getFinder();
// 重新定义视图目录
$view->prependLocation($path);
// 返回请求
return $next($request);
}
}
4. 最后注册中间件
在 app/Http/Kernel.php 类中 按需注册中间件
如注册全局中间件:
protected $middleware = [
\App\Http\Middleware\Template::class,
];
搞定, 就可以根据不同的设备加载不同的模板文件了
在控制中只需这样, 就可以根据不同的设备来加载不同的模板了
return view(‘registration.index’, $data);
如从 PC 设备打开网页: 加载 /resources/views/pc/registration/index.blade.php 模板
如从移动设备打开网页: 加载 /resources/views/mobile/registration/index.blade.php 模板
原文: Laravel 配置双模板