在之前一篇文章中我介紹了通過定義Response宏的方式來實現動態改變模板文件路徑以實現主題功能: laravel實現模板主題功能,但後來我發現這種方法有個弊端,在模板中使用@extends必須顯式指定模板路徑,這可能造成混亂,我決定還是改變思想,主題和主題之間應該是完全隔離的,不存在就是不存在,不要自動去另外的主題中尋找替代的模板。
而原來定義response宏的方式可以實現,但我決定使用更加規范的方法。
laravel的View類裡有一個方法 View::addNamespace ,這個方法在手冊"開發擴展包"一節中有提到,不得不說Laravel手冊排版邏輯混亂,這個方法說明應當放在"視圖"章節才是,題外話就不說了,先來說說這個方法吧。
laravel渲染視圖有一種寫法:
復制代碼 代碼如下:
View::make('namespace::path');
//例如 View::make('default::index.index');
如何定義namespace呢,就是通過這個方法啦:
復制代碼 代碼如下:
View::addNamespace('default',app_path().'/views/default');
聰明的朋友可能已經感覺到了,這個功能可以助我們實現模板主題化,比如:
復制代碼 代碼如下:
//注冊藍色主題
View::addNamespace('blue',app_path().'/views/blue');
//注冊紅色主題
View::addNamespace('red',app_path().'/views/red');
//注冊綠色主題
View::addNamespace('green',app_path().'/views/green');
之後調用:
復制代碼 代碼如下:
//渲染綠色主題下的index.index模板
View::make('green::index.index');
然而我們需要事先通過View::addNamespace方法先注冊這幾個主題的路徑映射,並且在渲染的時候需要顯式指定namespace.
我感覺不是很方便,難道View不能設定一個默認的namespace嗎?這樣我們只要一次設置比如:
復制代碼 代碼如下:
//我們可以把這個寫在 __construct 裡面
View::setDefaultNamespace('blue',app_path().'/views/blue');
之後:
復制代碼 代碼如下:
//實際上相當於 View::make('blue::index.index');
View::make('index.index');
更進一步,我們可以通過後台設置主題,把主題名寫進數據庫,前台讀取並設置主題:
復制代碼 代碼如下:
//假設從數據庫中讀取配置,Option是模型類
$theme = Option::getByKey('theme');
View::setDefaultNamespace($theme,app_path().'/views/'.$theme);
這樣就實現了後台切換主題了。
但是很遺憾,View並沒有setDefaultNamespace方法,所以我決定創建一個項目,專門針對laravel進行核心類庫擴展,這個功能已經實現,可以查看我的項目:項目地址 ,在src/Keepeye/Laravel/View/查看使用方法吧。
好了,關於laravel模板主題功能的實現,我們就探討到這裡了,希望大家能夠喜歡。