這是一篇很有年頭的文章了,不過其介紹的smarty模板引擎的相關知識,現在看來,仍然受益匪淺,此處分享,供大家參考。 用PHP實作MVC開發模式的邏輯層和表示層有多種模板引擎可供選擇,但官方引擎SMARTY誕生後,選擇就發生了變化。它的理念和實現都是相當"前衛"的。本文主要討論SMARTY之於其他模板引擎的不同特點,簡要介紹了該引擎的安裝及使用,並用一個小的測試案例對比了SMARTY和PHPLIB template的速度和易用性。 一、MVC需要模板 MVC最早是在SmallTalk語言的開發過程中總結出的一種設計模式,MVC分別代表了"模型"、"視圖"和"控制",目的就是讓不同的開發角色在大中型專案中各司其職。在網路應用程式的開發中,可以用下圖來表示各概念之間的關係。 該圖展示了一個簡單的WEB應用程序,用戶在瀏覽器上看到資訊是資料庫伺服器上的內容,但在這之前經過了應用程式伺服器加工。開發人員負責的就是建立資料結構、處理資料的邏輯、表示資料的方法。 96年CGI在中國開始流行的時候,早期的WEB程式設計師都是從HTML開始自學成材的,在PERL中print一行行的HTML並不是一件難事,但是隨著網路的一步步提速,頁面大小也從當初的二、三十K暴漲了十倍。寫CGI程式就產生了一個迫切的要求:分開PERL和HTML源碼。於是,社會進步體現在開發小組內部的分工。由於美工和程式設計師對互相的工作並不是十分熟悉,在進行合作的過程中需要用一種約定的"語言"進行交流。 這種語言不是我們的母語或英語,術語叫做"模板",邏輯和表示依靠它聯繫。它是結合了HTML和腳本語言特徵的一種表達方式。透過這種方式,表示層可以按照使用者所希望的格式來顯示經過邏輯層處理過的資料。如果你有Windows平台下MFC的開發經驗,那麼一定會很熟悉Document/Document Template/View的封裝,這就是一個很典型的MVC例子。對於Web應用來說,個人認為J2EE中的EJB/servlets/JSP是最強大的,當然還有簡潔優美的Structs。另一個很有名的實作就是COM/DCOM+ASP,這個組合在我國是最多人使用的。 透過幾種MVC實現在WEB應用程式裡的對比,可以得到一個關於模板的概念:一組插入了HTML的腳本或者說是插入了腳本HTML,透過這種插入的內容來表示變化的數據。下面給出一個模板檔案的例子,這個模板經過處理後在瀏覽器裡顯示"Hello, world!"
這裡暫且省略處理方式,在後面做專門對比討論。 二、為什麼選SMARTY? 對PHP來說,有很多模板引擎可供選擇,例如最早的PHPLIB template和後起之秀Fast template,經過數次升級,已經相當成熟穩定。如果你對目前手中的模板引擎很滿意,那麼......也請往下看,相信你作為一個自由軟體愛好者或追求效率和優雅的開發者,下面的SMARTY介紹多少會有點意思。 除了個人偏好的影響,我一直傾向於使用官方標準的實現,例如APACHE的XML引擎Axis。好處就是可以獲得盡可能好的相容性(例如早期MFC對於Win3x的相容性就比其它的應用程式框架好,當然現在各種版本都很完善了)。 SMARTY發布之前我一直使用的是 PEAR 中的Integrated Template eXtension。這個引擎和PHPLIB template、Fast template幾乎是相容的,從模板的語法到對模板的處理同出一轍:都是將模板讀入內存然後調用parse()函數,用數據對預置的標記進行替換。 下面來看看SMARTY是怎麼做的。接到request後,先判斷是否第一次請求該url,如果是,將該url所需的模板檔案"編譯"成php腳本,然後redirect;如果不是,就是說該url的模板已經被"編譯"過了,檢查不需要重編譯後可以馬上redirect,重編譯條件可以自己設定為固定時限,預設的是模板檔被修改。 怎麼樣,看起來是不是有點眼熟?想起來了--這不就是JSP的原理嘛!的確,這種"編譯"用在PHP這樣的解釋性腳本引擎上顯得匪夷所思,但是仔細想想,JAVA不也是由JVM解釋執行的嗎?這就叫"沒有做不到,只有想不到"。 既然談到了JAVA,就再對PHP的未來發表一點看法。 PHP官方網站上宣布了2003年底發布PHP5.0版。這個版本擁有許多嶄新的特性:例如異常處理,命名空間,更面向物件等等。可以說越來越向JAVA靠攏,SMARTY也是新特性之一,使得PHP更適用於大中型專案的開發。但似乎離我當初選擇它的原因──靈巧易用──越來越遠了。但就一個軟體的生存週期來看,PHP正處於成長期,開發者賦予它更多的功能,以期能勝任商業應用是利大於弊的。身為PHP的忠實用戶,肯定不希望PHP總是被指責"能力不足"吧? 為什麼選擇SMARTY,只因為它很像JSP?當然有更為充分的理由。首先,除了第一次編譯的成本比較高之外,只要不修改模板文件,編譯好的cache腳本就隨時可用,省去了大量的parse()時間;其次SMARTY像PHP一樣有豐富的函數庫,從統計字數到自動縮排、文字環繞以及正規表示式都可以直接使用;如果覺得不夠,例如需要資料結果集分頁顯示的功能,SMARTY還有很強的擴展能力,可以透過插件的形式進行擴充。 事實勝於雄辯。我設計了一個測試程序,透過速度和開發難度這兩個因素對比了一下SMARTY和PHPLIB template,選PHPLIB template的原因是在patrick的文章《在PHP世界中選擇最合適的模板》中有一個PHPLIB template對Fast template的競賽,結果PHPLIB template大獲全勝,這使得SMARTY有了一個很好的對手。在測試之前,先談談在安裝過程中需要注意的問題。 |