首頁 >php框架 >Laravel >Laravel配置雙模板的方法介紹(程式碼範例)

Laravel配置雙模板的方法介紹(程式碼範例)

不言
不言轉載
2019-03-02 13:43:173356瀏覽

這篇文章帶給大家的內容是關於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配置雙模板的方法介紹(程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除