本文實例講述了ThinkPHP使用Smarty第三方插件的方法。分享給大家供大家參考,具體如下:
如果你在使用ThinkPHP框架的時候不想采用TP自帶的模版系統,而使用第三方的模版系統,你有很多其他的選擇,在這裡我僅介紹Smarty這種比較官方,而且比較強大的模版系統。
由於Smarty兼容PHP4,因此,它的效率會相對低一點點,這個低只是相對的,估計等Smarty啥時候正式放棄PHP4的時候,效率可能會上很大一個台階。
在TP框架的PlugIns目錄下面,有一個SmartTemplate目錄,裡面就是系統自帶的Smarty插件。
使用方法如下:
1、在項目的Conf/Config.php文件裡加上:
return array( 'THINK_PLUGIN_ON' => true, 'TMPL_ENGINE_TYPE'=>'smarty', );
2、下載好Smarty,並將smarty的libs目錄整個拷至項目的PlugIns目錄下(說明一下,PlugIns目錄可能會不存在,需要自己建立),同時將libs目錄改名為SmartTemplate(希望沒有記錯,其實也就是與THINKPHP的PlugIns目錄裡的SmartyTemplate目錄同名即可),如果你不願意把目錄改成這個名字,那麼,你必須到TP的插件目錄裡修改插件文件,使之包含路徑正確。
3、注意修改每次修改action或模板文件後刪除Temp下的html文件
說明一下:上面的內容來自於官方,由lin_chaoqi朋友解答的,網址為:http://bbs.thinkphp.cn/viewthread.php?tid=305&highlight=smarty
在這裡我要提的方法是於上面不一樣的,黑黑
因為我在使用第三方模版插件的時候,特地看了TP的view.class.php發現了一些很重要的問題,那就是,如果采用第三方模版插件,那麼第三方模版插件的效率可能不能保證,因為View類的fetch方法在判斷是否為第三方插件之間,作了很多TP模版插件的自有處理,而這些對於使用第三方模版插件來說,幾乎是完全無效的,這些處理可能會給第三方插件帶來影響,同時也影響了第三方插件的執行效率。問題已經與流年溝通過,但由於改動可能會很大,或許最近幾個版本裡,流年都不會嘗試作改進吧,一是怕影響了那些已經使用第三方插件的程序,二來如果去除掉這些處理,那麼View類可能就不需要了。流年對於這樣的情況應該是不願意看到的。畢竟這也影響了原有系統的架構,估計流年得仔細考慮了……[當然從流年個人來說,肯定是希望大家都使用TP自有的模版插件,只是我目前對於smarty則是更加熟悉而己],但對於我這個使用者來說,我需要的是臨時解決方法,所以,就有了下面的內容。
為了解決這個問題,我只有從View.class.php裡下手,因為Action.class.php裡有一行:
$this->tpl = View::getInstance();
那麼,也就是說 tpl 這個變量是 View 的單例模式,檢查了一下View.class.php中的這個getInstance方法,發現裡面使用了 get_instance_of 這個函數(這個函數是有一點小BUG的,這裡不作解釋,但我目前也沒有更好的解決方法),於是我對getInstance和__construct兩個方法進行了改動,刪除了__construct方法,加上了init方法,改動代碼如下:
static function getInstance() { get_instance_of(__CLASS__,'init'); init ($type=''){ $type)) { $this->type = strToUpper( $type ); $this->type = strtoupper(C('TMPL_ENGINE_TYPE')); in_array( $this->type, array('PHP','THINK') ) ){ $type = ucfirst( strToLower( $this->type ) ); vendor( $type ); $type(); $this; return } public function if(!empty( }else{ } if ( ! return new } return }
也就是讓View類在實例化的時候,同時調用init方法。在這個方法裡,我將我自己的模版插件放到了第三方插件的目錄(Vendor)下。
切記切記:千萬不可漏掉最後一句return $this;,其實這就是我所說的get_instance_of的BUG,如果不加這句,那麼當type變量為PHP或THINK時,getInstance是無法返回實例的。
新的使用方法步驟如下:
1、修改項目的Conf/Config.php文件:
return array( 'THINK_PLUGIN_ON' => true, 'TMPL_ENGINE_TYPE'=>'TpSmarty', );
2、在TP的Vendor目錄下面,創建TpSmarty.php,內容如下:
<?php include_once(PLUGIN_PATH."smarty/Smarty.class.php"); TpSmarty extends Smarty { __construct (){ parent::Smarty(); $this->caching = true; $this->template_dir = TMPL_PATH; $this->compile_dir = CACHE_PATH ; $this->cache_dir = TEMP_PATH ; ?> class public function } }
上面是最簡單的寫法,實際使用中,這些變量請改為與你自己的站點相配合。
3、根據上面的文件裡的include_once函數,將smarty的libs目錄拷貝至項目的PlugIns目錄下,改名為:smarty(只需要與include_once中的目錄相匹配即可)
4、然後,在項目的方法裡就可以直接使用:
class IndexAction extends Action{ index(){ $this->assign('test','testss'); $this->display('default/index.html'); public function } } }
只是,使用了插件後,display方法的參數是模版的全路徑,而且不能留空(並非不能解決,只是要改動的代碼就會更多,目前這個方法是改動最少的)。
測試一下,是否正常了?呵呵 。
現在,我們把Config裡的模版引擎換回Think,同時在Tpl/default/目錄下建立Index目錄,裡面放上index.html,並修改上面的index()方法,將原來的$this->display('default/index.html'); 改為$this->display(); ,試一下,是不是也正常了?
更多關於thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《ThinkPHP常用方法總結》、《smarty模板入門基礎教程》及《PHP模板技術總結》。
希望本文所述對大家基於ThinkPHP框架的PHP程序設計有所幫助。