laravel 5 實現模板主題功能(續)_PHP教程
推薦:laravel 5 實現模板主題功能很多cms里都有模板主題功能,我們可以通過一個配置切換主題,這個功能在laravel下如何實現呢?今天我們就來探討下這個問題。 眾所周知,laravel渲染模板是通過View::make()實現的,需要顯式指定模板文件路徑: 代碼如下: function index() { return View::make('index.i
前面一篇文章,我們簡單討論了laravel模板主題功能,本文我們繼續探討laravel模板主題功能的實現,本次實現比較重,有興趣慢慢看吧。
在之前一篇文章中我介紹了通過定義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);
分享:Opcache導致php-fpm崩潰nginx返回502這篇文章主要介紹了Opcache導致php-fpm崩潰nginx返回502的解決方法,十分實用,需要的朋友可以參考下 我這個博客為了提高運行效率在vps上裝了opcache擴展,結果發現有個頁面返回502,其他頁面正常。 檢查了php-fpm日志,發現是php-fpm子進程不知道為什么會崩潰,然后把o
- 相關鏈接:
- 教程說明:
PHP教程-laravel 5 實現模板主題功能(續)。