Laravel配置双模板的方法介绍(代码示例)

互联网 19-3-2
本篇文章给大家带来的内容是关于Laravel配置双模板的方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

在开发过程中, 不时会遇到某些项目需要使用两套模板

如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配置双模板的方法介绍(代码示例)的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: laravel
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:Laravel核心分析之异常处理(代码)

相关资讯