很多cms裡都有模板主題功能,我們可以通過一個配置切換主題,這個功能在laravel下如何實現呢?今天我們就來探討下這個問題。
眾所周知,laravel渲染模板是通過View::make()實現的,需要顯式指定模板文件路徑:
代碼如下:
function index()
{
return View::make('index.index');
}
既然這樣,我們就可以自己實現模板主題功能,我們只需要將模板文件放到一個主題名稱對應的目錄裡就行,比如默認主題為 default 的話,我們就這樣寫:
代碼如下:
function index()
{
return View::make('default.index.index');
}
自定義主題 custom :
代碼如下:
function index()
{
return View::make('custom.index.index');
}
從配置文件中讀取主題名:
代碼如下:
function index()
{
return View::make(Config::get('app.theme','default').'.index.index');
}
這樣基本就實現模板主題化的功能了,但還存在一個問題,那就是custom主題必須實現所有default主題的所有模板,否則會導致某些頁面模板文件不存在報錯,那麼進一步優化:
代碼如下:
function index()
{
$theme = Config::get('app.theme','default');
$tpl = $theme.'.index.index';
if (!View::exists($tpl)) {
$tpl = 'default.index.index';
}
return View::make($tpl);
}
就是在渲染模板之前,先檢測模板文件是否存在,不存在的話則使用default主題中對應的模板。
這麼多行代碼,我們可以繼續封裝一下,這時候要用到Response對象了,我們知道 Response::view() 等同於 View::make(),而Response還有一個方法Response::macro()方法可以用來定義一個宏,我們可以把邏輯封裝到宏裡面:
代碼如下:
Response::macro('render',function($path,$data=array()){
$theme = Config::get('app.theme','default');
$tpl = $theme.'.'.$path;
if (!View::exists($tpl)) {
$tpl = 'default.' . $path;
}
return Response::view($tpl,$data);
});
使用:
代碼如下:
function index()
{
$bindings = array(
'title' => '首頁'
);
return Response::render('index.index',$bindings);
}
需要注意的是傳入模板的變量得通過Response::render的第二個參數。
今天的教程就先到這裡吧,後續我們再來深入分析一下,希望大家能夠喜歡。