laravel 5 實(shí)現(xiàn)模板主題功能(續(xù))

字號(hào):


    前面一篇文章,我們簡單討論了laravel模板主題功能,本文我們繼續(xù)探討laravel模板主題功能的實(shí)現(xiàn),本次實(shí)現(xiàn)比較重,有興趣慢慢看吧。
    在之前一篇文章中我介紹了通過定義Response宏的方式來實(shí)現(xiàn)動(dòng)態(tài)改變模板文件路徑以實(shí)現(xiàn)主題功能: laravel實(shí)現(xiàn)模板主題功能,但后來我發(fā)現(xiàn)這種方法有個(gè)弊端,在模板中使用@extends必須顯式指定模板路徑,這可能造成混亂,我決定還是改變思想,主題和主題之間應(yīng)該是完全隔離的,不存在就是不存在,不要自動(dòng)去另外的主題中尋找替代的模板。
    而原來定義response宏的方式可以實(shí)現(xiàn),但我決定使用更加規(guī)范的方法。
    laravel的View類里有一個(gè)方法 View::addNamespace ,這個(gè)方法在手冊"開發(fā)擴(kuò)展包"一節(jié)中有提到,不得不說Laravel手冊排版邏輯混亂,這個(gè)方法說明應(yīng)當(dāng)放在"視圖"章節(jié)才是,題外話就不說了,先來說說這個(gè)方法吧。
    laravel渲染視圖有一種寫法:
    代碼如下:
    View::make('namespace::path');
    //例如 View::make('default::index.index');
    如何定義namespace呢,就是通過這個(gè)方法啦:
    代碼如下:
    View::addNamespace('default',app_path().'/views/default');
    聰明的朋友可能已經(jīng)感覺到了,這個(gè)功能可以助我們實(shí)現(xiàn)模板主題化,比如:
    代碼如下:
    //注冊藍(lán)色主題
    View::addNamespace('blue',app_path().'/views/blue');
    //注冊紅色主題
    View::addNamespace('red',app_path().'/views/red');
    //注冊綠色主題
    View::addNamespace('green',app_path().'/views/green');
    之后調(diào)用:
    代碼如下:
    //渲染綠色主題下的index.index模板
    View::make('green::index.index');
    然而我們需要事先通過View::addNamespace方法先注冊這幾個(gè)主題的路徑映射,并且在渲染的時(shí)候需要顯式指定namespace.
    我感覺不是很方便,難道View不能設(shè)定一個(gè)默認(rèn)的namespace嗎?這樣我們只要一次設(shè)置比如:
    代碼如下:
    //我們可以把這個(gè)寫在 __construct 里面
    View::setDefaultNamespace('blue',app_path().'/views/blue');
    之后:
    代碼如下:
    //實(shí)際上相當(dāng)于 View::make('blue::index.index');
    View::make('index.index');
    更進(jìn)一步,我們可以通過后臺(tái)設(shè)置主題,把主題名寫進(jìn)數(shù)據(jù)庫,前臺(tái)讀取并設(shè)置主題:
    代碼如下:
    //假設(shè)從數(shù)據(jù)庫中讀取配置,Option是模型類
    $theme = Option::getByKey('theme');
    View::setDefaultNamespace($theme,app_path().'/views/'.$theme);