laravel 5 實現(xiàn)模板主題功能
來源:易賢網 閱讀:1133 次 日期:2015-03-04 10:42:43
溫馨提示:易賢網小編為您整理了“l(fā)aravel 5 實現(xiàn)模板主題功能”,方便廣大網友查閱!

很多cms里都有模板主題功能,我們可以通過一個配置切換主題,這個功能在laravel下如何實現(xiàn)呢?今天我們就來探討下這個問題。

眾所周知,laravel渲染模板是通過View::make()實現(xiàn)的,需要顯式指定模板文件路徑:

代碼如下:

function index()

{

return View::make('index.index');

}

既然這樣,我們就可以自己實現(xiàn)模板主題功能,我們只需要將模板文件放到一個主題名稱對應的目錄里就行,比如默認主題為 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');

}

這樣基本就實現(xiàn)模板主題化的功能了,但還存在一個問題,那就是custom主題必須實現(xiàn)所有default主題的所有模板,否則會導致某些頁面模板文件不存在報錯,那么進一步優(yōu)化:

代碼如下:

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主題中對應的模板。

這么多行代碼,我們可以繼續(xù)封裝一下,這時候要用到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的第二個參數。

更多信息請查看IT技術專欄

更多信息請查看網絡編程
易賢網手機網站地址:laravel 5 實現(xiàn)模板主題功能

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網