今天就跟大家聊聊有關(guān)利用laravel 5怎么實(shí)現(xiàn)一個(gè)模板主題功能,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
創(chuàng)新互聯(lián)建站主營來安網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app軟件開發(fā),來安h5小程序定制開發(fā)搭建,來安網(wǎng)站營銷推廣歡迎來安等地區(qū)企業(yè)咨詢laravel渲染模板是通過View::make()實(shí)現(xiàn)的,需要顯式指定模板文件路徑:
復(fù)制代碼 代碼如下:
function index()
{
return View::make('index.index');
}
既然這樣,我們就可以自己實(shí)現(xiàn)模板主題功能,我們只需要將模板文件放到一個(gè)主題名稱對應(yīng)的目錄里就行,比如默認(rèn)主題為 default 的話,我們就這樣寫:
復(fù)制代碼 代碼如下:
function index()
{
return View::make('default.index.index');
}
自定義主題 custom :
復(fù)制代碼 代碼如下:
function index()
{
return View::make('custom.index.index');
}
從配置文件中讀取主題名:
復(fù)制代碼 代碼如下:
function index()
{
return View::make(Config::get('app.theme','default').'.index.index');
}
這樣基本就實(shí)現(xiàn)模板主題化的功能了,但還存在一個(gè)問題,那就是custom主題必須實(shí)現(xiàn)所有default主題的所有模板,否則會導(dǎo)致某些頁面模板文件不存在報(bào)錯(cuò),那么進(jìn)一步優(yōu)化:
復(fù)制代碼 代碼如下:
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主題中對應(yīng)的模板。
這么多行代碼,我們可以繼續(xù)封裝一下,這時(shí)候要用到Response對象了,我們知道 Response::view() 等同于 View::make(),而Response還有一個(gè)方法Response::macro()方法可以用來定義一個(gè)宏,我們可以把邏輯封裝到宏里面:
復(fù)制代碼 代碼如下:
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);
});
使用:
復(fù)制代碼 代碼如下:
function index()
{
$bindings = array(
'title' => '首頁'
);
return Response::render('index.index',$bindings);
}
看完上述內(nèi)容,你們對利用laravel 5怎么實(shí)現(xiàn)一個(gè)模板主題功能有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。