淺談MVC框架中View層的優雅設計及實例
2024-07-21 02:14:44
供稿:網友
 
  在基于b/s的應用程序開發中,從基本的技術分工上來說就是兩大塊,一是軟件顯示界面,另一個是程序邏輯。在n年前的腳本語言時代,無論是asp、php還是jsp,我們基本是都是把這兩者柔和在一起的。盡管我們想方設法做好很多函數或者包含文件來努力達到軟件的復用,但仍然無法滿足多變的用戶需求,這主要是因為以前的純腳本編碼方式無法很好支持及應用面向對象(oo)領域中的強大功能。 
  在常見的b/s軟件項目中,界面的設計包括html界面、wap界面及其它由文本字符協議為基本表示的界面等。以我們接觸最多的html頁面為例子,在做這些界面的時候往往需要美工先使用photoshop或fireworks等圖形界面設計工具進行全局設計,然后再使用進行dreamweaver等html頁面制作工具進行加工制作。而強大的程序邏輯及后臺處理都是由服務器端程序完成,這些程序具有較高的穩定性,其開發工具如jbuilder、eclipse等對view層的界面無法很好的支持(當然那些用記事本寫界面的應用除外),這就使得很多mvc框架的設計都無法兩全齊美。 
  作位一個比較友好的mvc的框架,在簡化服務器應用開發的同時,還需要在view這一層設計上不要過多的影響到界面人員的工作,最基本的要求就是不要過多的加入一些設計軟件不支持的標簽等元素(如struts的很多標簽在dreamweaver中都不支持)。這里我們以easyjweb為例,探討在view層如何實現比較合理的設計。 
  easyjweb作為一個快速java web mvc框架,其設計目標不盡是要簡化軟件開發人員的代碼書寫工作,更是要能方便界面設計人員的工作。 
  當然,要使界面能跟后臺程序邏輯能融合,顯示界面及程序邏輯之間需要一定的對話協議在所難免。easyjweb作為一個mvc框架,同樣也存在著這樣的對話協議,這就是easyjweb中的界面模板標識語言。 
  在當前發布的版本中,easyjweb界面模板標識語言使用的是apache開源的velocity模板引擎(template engine),當然以后會根據際需要加入更多的模板引擎以供框架應用者選擇。 
  velocity是一個基于java的模板引擎(template engine),它允許任何人僅僅簡單的使用模板語言(template language)來引用由java代碼定義的對象。作為一個比較完善的模板引擎,velocity的功能是比較強大的,但強大的同時也增加了應用復雜性。 
  理論上你可以在easyjweb模板使用所有velocity的腳本及功能,但我們不推薦你在界面模板中使用過多過復雜的腳本表達方式,在萬不得已的情況下,不要在界面模板中加入任何復雜的邏輯,更不要在界面模板中加入變量聲明、邏輯運算符等等。 
  在easyjweb中,我們提供了四條基本的模板腳本語句,基本上就能滿足所有應用模板的要求。這四條模板語句很簡單,可以直接由界面設計人員來添加。在當前很多easyjweb的應用實踐中,我們看到,所有界面模板中歸納起來只有下面四種簡單模板腳本語句即可實現: 
  1、$!obj  直接返回對象結果。 
   
  如:在html標簽中顯示java對象msg的值。
$!msg
  在html標簽中顯示經過htmlutil對象處理過后的msg對象的值。
$!htmlutil.dosomething($!msg)
  2、#if($!obj) #else #end 判斷語句 
  如:在easyjweb各種開源應用中,我們經常看到的用于彈出提示信息msg的例子。
  #if($msg) 
  <script> 
  alert('$!msg'); 
  </script> 
  #end 
  上面的腳本表示當對象msg對象存在時,輸出<script>等后面的內容。 
  3、#foreach( $info in $list) $info.something #end  循環讀取集合list中的對象,并作相應的處理。 
   
  如:easyjf開源論壇系統中論壇首頁顯示熱門主題的html界面模板腳本 
  #foreach( $info in $hotlist1) 
<a href="/bbsdoc.ejf?easyjwebcommand=show&&cid=$!info.cid" target="_blank">$!info.title</a><br> 
  #end 
  上面的腳本表示循環遍歷hotlist1集合中的對象,并輸出對象的相關內容。 
   
  4、#macro(macroname)#end 腳本函數(宏)調用,不推薦在界面模板中大量使用。 
  如:在easyjf簡易訂銷管等系統中經常看到的一個排序狀態顯示的模板內容。 
  函數(宏)定義,一般放在最前面 
  #macro(orderpic $type) 
  #if ($orderfield.equals($type)) 
  <img src="http://www.survivalescaperooms.com/images/ico/${ordertype}.gif"> 
  #end 
  #end 
  具體的調用如:
<font color="#ffffff">頭銜#orderpic("title")</font> 
  總結:  
  當然,在實際應用項目中,為了實現界面的更加友好、人性化,會出現很多復、易變的需求。如根據對象的不同狀態,顯示不同的提示顏色、提示語音等功能。在這種時候,仍然要慎用太多的模板腳本功能,大多數需求都可以通過變通的方式解決,有些信息可以直接在對象中增加邏輯轉化信息,有些界面要求可以通過在界面中使用與特定界面有關的表達方式來實現,如html頁面中使用javascript、css,wap頁面中使用wmlscript等等。只有,這樣才能確保證你的系統核心不受界面的的影響及控制,才能更好的擴展及維護。 
  我們希望你能成為真正的程序高手,而不只是精通某個處于表層的腳本語言,因此也不希望廣大java開發人員在view層消耗太多的時間。