前面一篇文章,我們簡(jiǎn)單討論了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è)方法在手冊(cè)"開發(fā)擴(kuò)展包"一節(jié)中有提到,不得不說Laravel手冊(cè)排版邏輯混亂,這個(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)模板主題化,比如:
代碼如下:
//注冊(cè)藍(lán)色主題
View::addNamespace('blue',app_path().'/views/blue');
//注冊(cè)紅色主題
View::addNamespace('red',app_path().'/views/red');
//注冊(cè)綠色主題
View::addNamespace('green',app_path().'/views/green');
之后調(diào)用:
代碼如下:
//渲染綠色主題下的index.index模板
View::make('green::index.index');
然而我們需要事先通過View::addNamespace方法先注冊(cè)這幾個(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ù)庫(kù),前臺(tái)讀取并設(shè)置主題:
代碼如下:
//假設(shè)從數(shù)據(jù)庫(kù)中讀取配置,Option是模型類
$theme = Option::getByKey('theme');
View::setDefaultNamespace($theme,app_path().'/views/'.$theme);
更多信息請(qǐng)查看IT技術(shù)專欄