在正式開講之前,我們來探討一下為什么要使用JSF來實現(xiàn)SERVER ADF,這也是很多開發(fā)商跟我討論時經(jīng)常會問到的問題。
世界上有300種Java的framework,這個數(shù)字是我?guī)讉€月前聽到的,現(xiàn)在可能已經(jīng)不止這個數(shù)了。我曾經(jīng)用過的framework包括Structs,Hibernate,Spring。這些framework不但能加速開發(fā),而且會帶來全新的程序設(shè)計理念。我當(dāng)時的感覺是:原來程序還可以這樣寫! 當(dāng)然,這些framework都是開源免費,你不用擔(dān)心自己的良心受到譴責(zé),也不用擔(dān)心比爾蓋茨半夜敲門收錢。 在這300多種framework中,ESRI為什么選擇了JSF?各個framework有各個framework的好處。JSF最大的優(yōu)點就是:像 Swing 和 AWT 一樣,JSF 是一個可以提供一組標(biāo)準(zhǔn)的、可重用的 GUI 組件的開發(fā)框架。 原因之一: 行為與表示的完全分離。 行為和表現(xiàn)不分離的一個典型例子是普通的JSP 技術(shù),這一技術(shù)很好,因為很容易在 HTML(和類 HTML)頁面中混合 Java 代碼。這樣我們就可以使用強大的Java API的功能。當(dāng)然,很明顯的壞處是行為表現(xiàn)黏合在一起。而且代碼不容易重用。這讓我想起剛使用JSP技術(shù)時,在文本編輯器下寫JSP頁面,讀寫數(shù)據(jù)庫,并且在同一個頁面上顯示出來的痛苦回憶。 Model1架構(gòu)的出現(xiàn)使開發(fā)人員可以用javabean的方式進行開發(fā),舒服多了。當(dāng)然,還有更好的。 這就不得不提到著名的MVC結(jié)構(gòu),(MVC) model-view-controller架構(gòu)提供了一系列的設(shè)計模式,這些模式讓你可以輕松地應(yīng)用于程序地開發(fā),特別是有界面程序的開發(fā)。現(xiàn)在又有多少的程序是沒有界面的呢? Model包裝了商業(yè)邏輯,也包含了數(shù)據(jù)持久的代碼,包括存取數(shù)據(jù)庫或者存取文件。Model最好不要跟View有任何關(guān)系,它最好不要知道誰將顯示結(jié)果,是一個Swing界面,還是JSF界面,還是普通的JSP界面。為了做到這一點,事先的規(guī)劃要花一些時間,但是相信我,這些花的時間帶來的價值將超過你的想象。如果設(shè)計得當(dāng),許多用ArcGIS Engine開發(fā)的代碼可以輕松在Server中使用,不需要修改任何代碼。.net也是一樣。 View只用來顯示顯示邏輯,不能有任何商務(wù)邏輯。controller是view和model的橋梁,它和model進行交互,并且把結(jié)果顯示在Model中。顯示頁面的選擇也由controller進行選擇。我會在后面的講座中詳細(xì)解釋JSF中的Controller的實現(xiàn)。 Structs,Spring都實現(xiàn)了MVC的架構(gòu)。但是它們都沒有像JSF這樣,提供一個事件驅(qū)動的組件對象模型。大家可以想一想,一個平常在HTML中使用的標(biāo)簽, <input type="text" name="q">,在JSF框架中變成了一個組件,這個組件還可以有事件,而且可以對這個事件可以進行編程。這是多么得激動人心啊! GIS程序需要和用戶進行良好地交互,選擇一個事件驅(qū)動的framework,可以更加容易編程和實現(xiàn)。 這是ESRI選擇JSF的重要原因之一。 (未完待續(xù)) 為什么我們選擇JSF,而不是其它framework(續(xù)) 原因之二: 事件容易捆綁到服務(wù)器端代碼。
JSF提供了多個事件驅(qū)動的GUI控件, 比如最最常見的command button。這些command button會產(chǎn)生事件,我們有機會對事件進行編程;我在以前的講座中曾經(jīng)講過,ArcGIS Server的MapControl和command button是兄弟,他們都繼承自javax.faces.component.UICommand;是不是感覺很奇妙啊?繼承自UICommand的原因是要利用UICommand的很多事件,對鼠標(biāo)在Map Control上的動作,比如放大,縮小,需要產(chǎn)生事件,這些事件提交到相應(yīng)的監(jiān)聽器,監(jiān)聽器會對事件進行處理。有關(guān)于MapControl的問題先提這些,在后面的講座中我會詳細(xì)解釋。 舉一個簡單的例子吧,一個最簡單不過的fullextent工具,如果我自己來寫,可以寫成這樣: <h:commandButton id="redisplayCommand" type="submit" value="Full Extent" actionListener="#{getMapBean.getFullMap}" /> 這個按鈕,用來縮放到全圖,它的監(jiān)聽器是綁定到getMapBean的getFullMap方法,在該方法里面,我會將地圖的大小縮放到全圖范圍。代碼我會稍后貼上來。這就是JSF的事件捆綁到服務(wù)器代碼的功能。普通的一個button,點擊事件可以映射到后臺Bean的某一個方法,在后臺方法里面執(zhí)行商業(yè)邏輯,進行數(shù)據(jù)存取。這個概念跟普通的Swing程序的事件和監(jiān)聽器機制十分類似,Java程序員們看了肯定倍感親切。注意,剛才這個button沒有利用任何ADF的類,在我們的ADF中,所有要建大廈的材料都已經(jīng)給您準(zhǔn)備好,fullExtent功能只需要三行代碼即可實現(xiàn)。 事件容易捆綁到服務(wù)器端代碼,這是ESRI選擇JSF作為我們ADF底層的另外一個重要的原因。 |