ThinkPHP使用Smarty第三方插件方法小結(jié)
本文實例講述了ThinkPHP使用Smarty第三方插件的方法。分享給大家供大家參考,具體如下:
如果你在使用ThinkPHP框架的時候不想采用TP自帶的模版系統(tǒng),而使用第三方的模版系統(tǒng),你有很多其他的選擇,在這里我僅介紹Smarty這種比較官方,而且比較強大的模版系統(tǒng)。
由于Smarty兼容PHP4,因此,它的效率會相對低一點點,這個低只是相對的,估計等Smarty啥時候正式放棄PHP4的時候,效率可能會上很大一個臺階。
在TP框架的PlugIns目錄下面,有一個SmartTemplate目錄,里面就是系統(tǒng)自帶的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文件
說明一下:上面的內(nèi)容來自于官方,由lin_chaoqi朋友解答的,網(wǎng)址為:http://bbs.thinkphp.cn/viewthread.php?tid=305&highlight=smarty
在這里我要提的方法是于上面不一樣的,黑黑
因為我在使用第三方模版插件的時候,特地看了TP的view.class.php發(fā)現(xiàn)了一些很重要的問題,那就是,如果采用第三方模版插件,那么第三方模版插件的效率可能不能保證,因為View類的fetch方法在判斷是否為第三方插件之間,作了很多TP模版插件的自有處理,而這些對于使用第三方模版插件來說,幾乎是完全無效的,這些處理可能會給第三方插件帶來影響,同時也影響了第三方插件的執(zhí)行效率。問題已經(jīng)與流年溝通過,但由于改動可能會很大,或許最近幾個版本里,流年都不會嘗試作改進吧,一是怕影響了那些已經(jīng)使用第三方插件的程序,二來如果去除掉這些處理,那么View類可能就不需要了。流年對于這樣的情況應(yīng)該是不愿意看到的。畢竟這也影響了原有系統(tǒng)的架構(gòu),估計流年得仔細考慮了……[當然從流年個人來說,肯定是希望大家都使用TP自有的模版插件,只是我目前對于smarty則是更加熟悉而己],但對于我這個使用者來說,我需要的是臨時解決方法,所以,就有了下面的內(nèi)容。
為了解決這個問題,我只有從View.class.php里下手,因為Action.class.php里有一行:
$this->tpl = View::getInstance();
那么,也就是說 tpl 這個變量是 View 的單例模式,檢查了一下View.class.php中的這個getInstance方法,發(fā)現(xiàn)里面使用了 get_instance_of 這個函數(shù)(這個函數(shù)是有一點小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類在實例化的時候,同時調(diào)用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目錄下面,創(chuàng)建TpSmarty.php,內(nèi)容如下:
<?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、根據(jù)上面的文件里的include_once函數(shù),將smarty的libs目錄拷貝至項目的PlugIns目錄下,改名為:smarty(只需要與include_once中的目錄相匹配即可)
4、然后,在項目的方法里就可以直接使用:
class IndexAction extends Action{ index(){ $this->assign('test','testss'); $this->display('default/index.html'); public function } } }
只是,使用了插件后,display方法的參數(shù)是模版的全路徑,而且不能留空(并非不能解決,只是要改動的代碼就會更多,目前這個方法是改動最少的)。
測試一下,是否正常了?呵呵 。
現(xiàn)在,我們把Config里的模版引擎換回Think,同時在Tpl/default/目錄下建立Index目錄,里面放上index.html,并修改上面的index()方法,將原來的$this->display('default/index.html'); 改為$this->display(); ,試一下,是不是也正常了?
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《ThinkPHP常用方法總結(jié)》、《smarty模板入門基礎(chǔ)教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。
相關(guān)文章
Laravel路由研究之domain解決多域名問題的方法示例
這篇文章主要介紹了Laravel 路由研究之domain解決多域名問題的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04Zend Framework教程之Zend_Db_Table_Row用法實例分析
這篇文章主要介紹了Zend Framework教程之Zend_Db_Table_Row用法,詳細講述了Zend_Db_Table_Row的功能,并結(jié)合實例形式詳細分析了Zend_Db_Table_Row操作數(shù)據(jù)的相關(guān)技巧,需要的朋友可以參考下2016-03-03ThinkPHP頁面跳轉(zhuǎn)success與error方法概述
這篇文章主要介紹了ThinkPHP頁面跳轉(zhuǎn)success與error方法概述,需要的朋友可以參考下2014-06-06thinkphp3.2框架集成QRcode生成二維碼的方法分析
這篇文章主要介紹了thinkphp3.2框架集成QRcode生成二維碼的方法,結(jié)合實例形式分析了QRcode的下載、擴展以及thinkphp3.2使用QRcode生成二維碼的相關(guān)操作技巧,需要的朋友可以參考下2020-03-03laravel使用組件實現(xiàn)微信網(wǎng)頁授權(quán)登入
這篇文章主要介紹了laravel使用組件實現(xiàn)微信網(wǎng)頁授權(quán)登入,使用laravel組件 laravel-wechat調(diào)用,使用起來很方便,有需要的同學可以學習下2021-03-03