明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

在PHP世界中選擇最合適的模板--比較PHPLIB Template與FastTemplate

[摘要]PHP工程中的模板應(yīng)用,是進(jìn)行中型乃至大型項(xiàng)目中建議采用的處理表現(xiàn)層的好辦法。但是具體到模板的實(shí)施,采用何種現(xiàn)有的模板技術(shù)卻需要進(jìn)行一番比較。PHP世界中比較受關(guān)注的模板處理有PHPLIB Template和FastTemplate兩種,我們對(duì)技術(shù)的易用性和速度進(jìn)行了評(píng)測(cè)--想知道結(jié)果嗎?事情的起...
PHP工程中的模板應(yīng)用,是進(jìn)行中型乃至大型項(xiàng)目中建議采用的處理表現(xiàn)層的好辦法。但是具體到模板的實(shí)施,采用何種現(xiàn)有的模板技術(shù)卻需要進(jìn)行一番比較。
PHP世界中比較受關(guān)注的模板處理有PHPLIB Template和FastTemplate兩種,我們對(duì)技術(shù)的易用性和速度進(jìn)行了評(píng)測(cè)--想知道結(jié)果嗎?

事情的起因:你用過(guò)FastTemplate嗎?
對(duì)于PHP工程中的模板應(yīng)用,其實(shí)我和我的同事們已經(jīng)在許多的項(xiàng)目中接觸過(guò)--關(guān)于它的好處,我想無(wú)論是在實(shí)際開發(fā)階段還是上升到設(shè)計(jì)模式的角度都已經(jīng)有很多"前輩先哲"討論過(guò)了。就項(xiàng)目實(shí)施而言,在一些中型甚至大型的項(xiàng)目中,有效的將HTML(還有其他文本形式的表現(xiàn)層)和PHP代碼分開,不僅在開發(fā)階段可以分別提高界面設(shè)計(jì)人員和應(yīng)用程序編寫人員的工作效率,更會(huì)給項(xiàng)目的測(cè)試和維護(hù)帶來(lái)巨大的便利。

但是--本文的目的不是討論模板的優(yōu)缺點(diǎn),也不是作為指導(dǎo)性的教程講授如何在PHP項(xiàng)目中使用模板,而是以應(yīng)用的視角比較兩種PHP世界中最為流行的模板處理方式(其實(shí)只不過(guò)是兩種模板類):PHPLIB Template和FastTemplate。

其實(shí)我一直都在"安靜"的使用著PHPLIB Template--很穩(wěn)定而且看上去速度也不錯(cuò),以至于我并不想再去不安的尋找可能更好的替代品--雖然我也知道這個(gè)地球上還有FastTemplate這樣的東西(而且還在Perl的世界中大名鼎鼎)。直到有一天,有一個(gè)同事問(wèn)我:"不知道FastTemplate怎么樣?為什么我們不試試FastTemplate呢?"

"好吧,就讓我們?cè)囋嚕?quot;不過(guò)作為一個(gè)穩(wěn)妥的方法,在任何新的模式或者方法引入項(xiàng)目之前,最好能夠更加全面的了解它,以及找到一個(gè)或者幾個(gè)足夠說(shuō)服自己和同事去采用它的理由--對(duì)于FastTemplate也不例外。

主角出場(chǎng):了解PHPLIB Template以及FastTemplate
前面已經(jīng)說(shuō)過(guò),我已經(jīng)使用PHPLIB有一段時(shí)間了--我想屏幕前的你也許和我一樣,也對(duì)這個(gè)優(yōu)秀的工具類庫(kù)印象很深吧!同樣,當(dāng)我開始尋求模板的解決辦法時(shí),很自然的就會(huì)在最接近身邊的工具箱里搜尋,于是我找到了PHPLIB中的Template類。在最初的很快瀏覽完它提供的API之后(當(dāng)然還得感謝PHPLIB詳盡的文檔),我就開始了使用它的歷程--直到現(xiàn)在。

而FastTemplate似乎名氣更響亮一些,在其發(fā)跡的Perl世界中自然是這樣,在PHP世界中似乎也是,單單從這一點(diǎn)上就足夠讓人相信它的能力了。

關(guān)于兩者的使用辦法,本來(lái)我想在這里多廢話幾句的;但是畢竟覺(jué)得自己恐怕專門寫出兩篇教程來(lái)也沒(méi)有現(xiàn)有的教程受歡迎--在本文的參考資料中有關(guān)于PHPLIB Template和FastTemplate的有名教程,如果你自認(rèn)還沒(méi)有對(duì)這兩種模板或者其中的一種有所認(rèn)識(shí),建議你先去看看那兩篇文章,應(yīng)該會(huì)得到不少有益的模板應(yīng)用知識(shí)。

(一番鼠標(biāo)點(diǎn)擊以及眼球轉(zhuǎn)動(dòng)甚至親自編寫測(cè)試代碼之后,)現(xiàn)在你對(duì)兩種模板都有了一些了解,也許已經(jīng)發(fā)現(xiàn)了它們之間的很多相似之處,在下面我就會(huì)將這些地方歸納一下。

變量的設(shè)置
很明顯,{FOO}或者{BAR}的形式在兩種模板中都是指定的形式;也就是說(shuō),兩種模板處理方式中,模板文件本身的外貌應(yīng)該可以是一致的(比如都是HTML文件中間含有將要被替換的以{}標(biāo)識(shí)的變量)。
模板類的初始化(類的構(gòu)建器)
都需要在構(gòu)建模板類的時(shí)候指定模板文件存在的目錄位置。
變量的替換
模板處理中最常用的就是變量替換,兩種方式除了方法名不同之外(PHPLIB Template采用set_var(),而FastTemplate采用assign()),用法幾乎也是一致的--可以采用(key, value)的方式,也可以直接傳遞一個(gè)數(shù)組(array(key=>value))。
模板文件的處理
都是采用為每一個(gè)模板文件指定一個(gè)句柄(handler)的辦法,同時(shí)句柄也可以作為變量的值替換另一模板文件中的變量。
解析、輸出過(guò)程
都是需要調(diào)用parse()方法(這個(gè)方法名竟然是相同的)將需要輸出的模板文件解析后賦值給一個(gè)句柄,然后調(diào)用各自輸出的方法(PHPLIB Template中是p(),F(xiàn)astTemplate中是FastPrint())輸出該句柄的內(nèi)容并結(jié)束處理。
重復(fù)解析的過(guò)程
比如從數(shù)據(jù)庫(kù)中取出幾條記錄需要顯示而模板文件只有可替換的一行變量的時(shí)候,就很需要這樣的功能。兩者都具有這樣的功能,只是使用時(shí)稍稍有些不同而已(PHPLIB Template采用parse(handler, value, true),而FastTemplate采用parse(handler, .value)在值的前面多加一個(gè)點(diǎn)),應(yīng)該說(shuō)PHPLIB Template的方法構(gòu)造得相對(duì)優(yōu)美一點(diǎn)。
區(qū)塊解析的過(guò)程(或者可以稱作動(dòng)態(tài)解析)
想像一下你需要從數(shù)據(jù)庫(kù)中取出符合條件的數(shù)據(jù)并顯示在網(wǎng)頁(yè)中--但是因?yàn)闂l件會(huì)不盡相同,你并不能明確的知道會(huì)有多少條數(shù)據(jù)--這時(shí)候如果你又要采用模板,那么區(qū)塊就是最好的選擇。它是在模板中用特定的符號(hào)定義的部分,這一部分可以反復(fù)的被解析并添加到(而不是前一次的解析被后一次覆蓋)輸出網(wǎng)頁(yè)中。區(qū)塊也許就像下面顯示的一樣(左邊是PHPLIB Template采用的區(qū)塊設(shè)置,而右邊則是FastTemplate采用的):

好吧,如果你對(duì)以上蒼白的文字介紹還是有些摸不著頭腦,那么我們就來(lái)看看兩個(gè)詳盡的模板處理的例程吧。ㄈ绻阌信d趣對(duì)后面的測(cè)試代碼進(jìn)行發(fā)掘,就會(huì)發(fā)現(xiàn)其實(shí)以下的兩個(gè)例子都來(lái)自那里)


怎么樣,是不是感覺(jué)幾乎是一致的?下面是區(qū)塊解析的例子,你也會(huì)發(fā)現(xiàn)同樣的效果:


我們的測(cè)試目標(biāo)和結(jié)果
結(jié)束了對(duì)PHPLIB Template和FastTemplate的了解,應(yīng)該可以進(jìn)入本文的正題了--在應(yīng)用環(huán)境中當(dāng)然應(yīng)該選擇易于使用同時(shí)速度理想的部件構(gòu)建系統(tǒng),那么對(duì)于這樣的兩種類似技術(shù),進(jìn)行評(píng)測(cè)非常有必要。評(píng)測(cè)應(yīng)該是由兩部分組成:技術(shù)的使用難度和速度的快慢程度--前者是評(píng)論的部分,而后者是測(cè)試的部分。對(duì)于前者,我們主要針對(duì)兩個(gè)類提供的API進(jìn)行評(píng)論;對(duì)于后者,我們會(huì)讓測(cè)試的數(shù)據(jù)來(lái)說(shuō)話,當(dāng)然這中間免不了需要編寫一些簡(jiǎn)單的測(cè)試代碼。

回合一:技術(shù)的易用性
這一回合主要是探討PHPLIB Template和FastTemplate提供的API的使用情況。應(yīng)該說(shuō),前者提供的API更符合PHP的一些常見(jiàn)編碼慣例(特別是當(dāng)你的項(xiàng)目中采用了PHPLIB的其他類時(shí),這樣的規(guī)范性會(huì)對(duì)整個(gè)項(xiàng)目有好的影響);而后者的一些方法名總覺(jué)得有些別扭(希望你不要覺(jué)得這只是我的狹隘看法,比如FastPrint()等等),同時(shí)方法的參數(shù)也不是非常"地道",這一點(diǎn)你也可以從剛才的代碼看出來(lái)。

另外一點(diǎn)需要指出的是,對(duì)于模板區(qū)塊的解析,F(xiàn)astTemplate直到最近的版本才開始支持。也就是說(shuō),如果你采用了之前的版本,在處理諸如數(shù)據(jù)庫(kù)中記錄的輸出等內(nèi)容時(shí),不得不把這塊內(nèi)容獨(dú)立存儲(chǔ)在某處,然后在模板分析處理時(shí)附加上這個(gè)文件--真是一件讓人難受的事情,尤其是對(duì)網(wǎng)頁(yè)設(shè)計(jì)人員而言。

當(dāng)然還有一點(diǎn)需要考察--那就是對(duì)于PHP版本的支持。PHPLIB產(chǎn)生在PHP3的時(shí)代,這一點(diǎn)和FastTemplate差不多;但是根據(jù)我們的應(yīng)用,PHPLIB在現(xiàn)在的PHP4環(huán)境下運(yùn)行相當(dāng)好,而FastTemplate的網(wǎng)頁(yè)上則顯示了一些信息表明對(duì)于PHP4也許它還有一些BUG存在。

好了,講了這么多(也許你會(huì)覺(jué)得都是FastTemplate的壞話),這個(gè)回合的勝利者很明顯:PHPLIB Template,尤其是你同時(shí)在使用PHPLIB的其他類時(shí),這樣的技術(shù)易用性更加明顯(你將不會(huì)對(duì)這些出自同一個(gè)開發(fā)小組的API感到陌生)。

回合二:處理速度
也許這才是很多人最關(guān)注的部分--在這個(gè)回合中,我們會(huì)采用兩種模板處理的方式:一種是常規(guī)的分析、替換,另一種是對(duì)區(qū)塊的解析、替換--同時(shí)這樣的兩種方式也是在實(shí)際系統(tǒng)中應(yīng)用最多的:前者是一般的頁(yè)面處理,后者是關(guān)于數(shù)據(jù)庫(kù)內(nèi)容的輸出處理。同時(shí),由于兩種模板類采用的模板文件的格式基本相同,使得我們可以提供幾乎一致的模板文件分別供兩種模板解析,更增加了測(cè)試的可信度。

開展這樣的速度測(cè)試之前會(huì)擬定一個(gè)測(cè)試方案,簡(jiǎn)單說(shuō)來(lái)就是對(duì)于兩種處理方式分別編寫兩個(gè)PHP測(cè)試頁(yè)面,同時(shí)有一個(gè)控制測(cè)試的頁(yè)面多次調(diào)用這兩個(gè)頁(yè)面并記錄時(shí)間供采集測(cè)試數(shù)據(jù)。(如果有興趣你還可以參考以下詳細(xì)的測(cè)試方案,也許會(huì)對(duì)你深入了解這次測(cè)試有所幫助)

小結(jié)--在整個(gè)測(cè)試系統(tǒng)完成之后,我們應(yīng)該能夠得到/test目錄中如下的文件清單:

(有點(diǎn)復(fù)雜的測(cè)試方案)
首先是確定測(cè)試的硬件和軟件環(huán)境--硬件肯定是自己的機(jī)器了,Intel Celeron 733MHz, 256M RAM,40G HDD;軟件平臺(tái)中OS為Win2K Pro,Web服務(wù)器為Apache+PHP,且以模塊方式運(yùn)行。

其次是規(guī)劃這次測(cè)試的系統(tǒng)--當(dāng)然先在Web服務(wù)器的文檔根目錄下開一個(gè)tpl_test的新目錄用以放置這個(gè)測(cè)試的所有文件;然后在/tpl_test下建立include目錄以存放兩個(gè)模板類文件(我們測(cè)試的核心,以.inc.php為文件擴(kuò)展名)以及一個(gè)測(cè)試類文件(包括了計(jì)時(shí)和記錄日志以及讀取日志并分析等功能,以.inc.php為文件擴(kuò)展名)和一個(gè)數(shù)據(jù)文件(為區(qū)塊解析的測(cè)試做準(zhǔn)備,主要包含了一個(gè)二維數(shù)組,同樣以.inc.php為文件擴(kuò)展名),建立ihtml目錄存放使用的模板文件(需要被解析的模板文件,以.ihtml為文件擴(kuò)展名),建立logs目錄存放測(cè)試產(chǎn)生的日志(后面就是發(fā)現(xiàn),其實(shí)測(cè)試的數(shù)據(jù)就是由對(duì)這些日志的分析得到的,以.log為文件擴(kuò)展名)。當(dāng)然,兩種模板的處理PHP文件就放在/test目錄下。這次測(cè)試最關(guān)鍵的一點(diǎn)是,還需要建立一個(gè)PHP文件,對(duì)以上提到的負(fù)責(zé)模板處理的文件進(jìn)行數(shù)次調(diào)用:比如一個(gè)文件fast_test.php是采用FastTemplate解析模板的,而phplib_test.php是采用PHPLIB Template解析的,那么這個(gè)得出結(jié)果的PHP文件就負(fù)責(zé)多次以HTTP的方式請(qǐng)求以上的兩個(gè)頁(yè)面以獲得測(cè)試數(shù)據(jù)。

選擇待解析的模板和PHP程序編寫--因?yàn)閮煞N模板處理方式對(duì)于模板文件本身的格式要求幾乎一致(比如待替換變量都采用{VAR}的形式等等),因此可以盡量保證同一測(cè)試中兩者選用的模板盡可能相同以謀求測(cè)試的最大公正性;同時(shí)在前文提到,為模擬現(xiàn)實(shí)系統(tǒng)中常用的兩種模板應(yīng)用:一般的頁(yè)面處理和對(duì)數(shù)據(jù)庫(kù)內(nèi)容的輸出處理,測(cè)試使用的模板文件也分成兩種:一種是普通的帶有一些待替換變量的模板文件,另一種是帶有區(qū)塊的需要根據(jù)應(yīng)輸出的內(nèi)容反復(fù)替換的模板文件。同樣對(duì)于這兩種模板文件,也需要分別編寫兩種不同的PHP文件進(jìn)行解析。

測(cè)試方法--在瀏覽器中向/test/result.php提出請(qǐng)求,需要帶參數(shù)type=[simple complex],在返回的結(jié)果中即可看到兩種模板在簡(jiǎn)單或者復(fù)雜模式下的測(cè)試結(jié)果。



Level 1 Level 2 Level 3 Remark
/test 測(cè)試系統(tǒng)的根目錄

result.php 進(jìn)行測(cè)試并產(chǎn)生結(jié)果的PHP文件,測(cè)試時(shí)只需要在瀏覽器中請(qǐng)求該頁(yè)面即可獲得測(cè)試信息
simple__test_phplib.php 使用PHPLIB Template對(duì)一般模板進(jìn)行分析的PHP文件
simple__test_fast.php 使用FastTemplate對(duì)一般模板進(jìn)行分析的PHP文件
complex__test_phplib.php 使用PHPLIB Template對(duì)帶區(qū)塊模板進(jìn)行分析的PHP文件
complex__test_fast.php 使用FastTemplate對(duì)帶區(qū)塊模板進(jìn)行分析的PHP文件

/include 包含PHP類文件.inc.php
phplibTemplate.inc.php PHPLIB Template類文件
FastTemplate.inc.php FastTemplate類文件
TplTest.inc.php 測(cè)試中需要使用的測(cè)試類,包含諸如計(jì)時(shí)、讀取/分析日志等方法。
data.inc.php 測(cè)試帶區(qū)塊模板時(shí)采用的數(shù)據(jù)文件。

/ihtml 包含模板文件.ihtml
simple_phplib.ihtml 采用PHPLIB Template處理的一般模板文件
simple_fast.ihtml 采用FastTemplate處理的一般模板文件
complex_phplib.ihtml 采用PHPLIB Template處理的帶區(qū)塊的模板文件
complex_fast.ihtml 采用FastTemplate處理的帶區(qū)塊的模板文件

/logs 包含日志文件.log
simple_phplib.log 采用PHPLIB Template處理一般模板生成的日志
simple_fast.log 采用FastTemplate處理一般模板生成的日志
complex_phplib.log 采用PHPLIB Template處理帶區(qū)塊模板生成的日志
complex_fast.log 采用FastTemplate處理帶區(qū)塊模板生成的日志

經(jīng)過(guò)了測(cè)試系統(tǒng)的設(shè)計(jì)和編寫,并且向負(fù)責(zé)網(wǎng)頁(yè)設(shè)計(jì)的同事討來(lái)兩個(gè)模板之后,我們就可以訪問(wèn)這個(gè)系統(tǒng)了--前期的辛勤勞動(dòng)使得現(xiàn)在觀看結(jié)果的工作只需要在瀏覽器的地址欄中打入 http://localhost/tpl_test/result.php?type=[simple complex] (如果你是在其他的非本地服務(wù)器中進(jìn)行這個(gè)測(cè)試,那么域名應(yīng)采用所在服務(wù)器的域名--比如我自己的機(jī)器叫做patrick等等)。下面是我自己在某一次的測(cè)試中獲得的結(jié)果:(測(cè)試結(jié)果數(shù)據(jù)解釋)

名稱 解釋 備注
amount 測(cè)試總數(shù)(連續(xù)請(qǐng)求該頁(yè)面總數(shù)) 該參數(shù)可在result.php文件中修改
max_seq 最大處理時(shí)間的序號(hào) 范圍在1-amount之間
max_value 最大處理時(shí)間的值 峰值數(shù)據(jù)供參考
min_seq 最小處理時(shí)間的序號(hào) 范圍在1-amount之間
min_value 最小處理時(shí)間的值 峰值數(shù)據(jù)供參考
average 平均處理時(shí)間 測(cè)試中最有價(jià)值的數(shù)據(jù)







當(dāng)然,如果你覺(jué)得一次測(cè)試的結(jié)果并不可靠,可以反復(fù)按下瀏覽器的刷新按鈕,就能夠觀察到不同測(cè)試的結(jié)果(理論上應(yīng)該是相差無(wú)幾)。

測(cè)試結(jié)果以及頒發(fā)"XX選擇獎(jiǎng)"
好了,在偏重速度測(cè)試的回合二中PHPLIB Template以驚人的2倍的速度戰(zhàn)勝了FastTemplate;而同時(shí)在第一回合中PHPLIB Template有以良好的API設(shè)計(jì)和易用性占得上風(fēng)。結(jié)果顯而易見(jiàn)--我們的選擇獎(jiǎng)當(dāng)然頒發(fā)給了PHPLIB Template,同時(shí)這次的測(cè)試也讓我們對(duì)PHPLIB這個(gè)類庫(kù)設(shè)計(jì)有了更深的了解。

主觀評(píng)價(jià)
既然有了結(jié)果,那么FastTemplate自然也就不能進(jìn)入我們的項(xiàng)目了--雖然從結(jié)果上看來(lái)我們花費(fèi)了半天的時(shí)間得到了一個(gè)毫無(wú)變化的結(jié)果(PHPLIB Template繼續(xù)很好的在項(xiàng)目中使用),但是測(cè)試的過(guò)程卻是很有價(jià)值的,特別是采用PHP進(jìn)行測(cè)試的方法,應(yīng)該會(huì)在以后的類似決策中起到一定參考作用。

參考資料
本文中的測(cè)試代碼下載 (article_256.zip)

介紹PHPLIB Template和FastTemplate的著名文章

Templates, The PHPLIB Way
by David Orr, May of 2000
(http://www.phpbuilder.com/columns/david20000512.php3 )
(PHPLIB Template)
Templates - why and how to use them in PHP3
by Sascha Schumann, March of 1999
(http://www.phpbuilder.com/columns/sascha19990316.php3 )
(FastTemplate)
PHPLIB Template和FastTemplate的主頁(yè)

PHP Library Homepage
(http://phplib.netuse.de )
FastTemplate Homepage
(http://www.thewebmasters.net/php/FastTemplate.phtml )
其他模板處理文章以及其他關(guān)于PHP的資料
PHP Builder (http://www.phpbuilder.com )

以上文章的中文譯本以及其他的中文PHP資料
PHP中文用戶(http://phpuser.com )