選擇JSF的理由:從UI組件開始
記得華為總裁任正非說過,華為是因?yàn)闊o知才走上通信產(chǎn)業(yè)之路的。我在2004年年中開始接觸JSF時(shí),也是因?yàn)闊o知。幾乎沒有Java經(jīng)驗(yàn),Web更是一片空白,寫了一個(gè)半吊子的JSP程序后,我居然判了JSP的死刑,鐵下心來鉆研我的JSF去了。無知者無畏,說得一點(diǎn)也不錯(cuò)。
從JSP起步,第二級(jí)臺(tái)階,也許Struts是最合適的。沒有復(fù)雜的概念,沒有深?yuàn)W的理論,容易理解,上手快,從JSP向Struts的過渡顯得特別自然。這是Struts流行的原因之一。如果當(dāng)時(shí)請(qǐng)教過任何一個(gè)Java高手,我十有八九會(huì)以Struts作為我的JSP替代技術(shù),并且很有可能成為Struts的發(fā)燒友??墒?,機(jī)緣巧合,我選擇了JSF。
正應(yīng)了那句俗語:“傻人有傻福。”采用JSF技術(shù)后,Web編程如有神助,一個(gè)月時(shí)間,我和一個(gè)剛畢業(yè)的程序員寫出了一個(gè)規(guī)模不小的Web程序:126張數(shù)據(jù)庫表,346個(gè)JSP頁面,458K Java源程序,還包括84頁的《需求規(guī)格說明書》和189頁的《數(shù)據(jù)庫設(shè)計(jì)說明書》。即便是桌面應(yīng)用,這樣規(guī)模的程序在一個(gè)月內(nèi)完成,老板也該偷著笑了。其實(shí),效率的提高,完全是JSF的功勞。正如Sun在JSF的規(guī)范中所宣稱的那樣,JSF極大地簡化了Java的 Web編程。
首先,在JSF中,頁面干凈了許多。無需聲明Javabean,也不用嵌入Scriptlet,沒有多余的符號(hào),只是一些擴(kuò)展標(biāo)簽而已,看上去規(guī)范而不失優(yōu)雅,讓人賞心悅目。程序員多半是完美主義者,眼睛里容不得丑陋的代碼,我認(rèn)識(shí)的一些程序員,平時(shí)不修邊幅,可以整個(gè)冬天都穿同一件夾克,袖口磨得油光發(fā)亮,但他們的程序卻整潔得讓人嫉妒。
其次,JSP中趾高氣揚(yáng)的Request和Response對(duì)象淡出了JSF。在典型的JSF應(yīng)用中,程序員基本上沒有直接操作Request和Response對(duì)象的必要,因?yàn)榭蚣茈[藏了對(duì)這兩個(gè)對(duì)象的處理細(xì)節(jié)。不論是從Request中解碼參數(shù),還是將數(shù)據(jù)編碼到Reponse中,都不需要程序員寫任何代碼,JSF知道該怎么做。當(dāng)然,如果非要訪問Request,JSF的隱含對(duì)象為程序員提供了可能。
JSF的UI組件
UI組件是JSF最具特色的組成部分。與桌面程序的UI組件不同的是,JSF的UI組件是服務(wù)器端的,但是,在JSF框架的支撐下,這些服務(wù)器端的UI組件,在程序員看來和桌面程序的UI組件沒什么不同。我用的Jbuilder版本不支持JSF頁面設(shè)計(jì)的所見即所得,當(dāng)我拖動(dòng)一個(gè)UI組件到頁面上時(shí),Jbuilder為我生成的,是一段標(biāo)簽文本,跟隨著我的鼠標(biāo),放在指定的位置。一個(gè)服務(wù)端UI組件就是這樣誕生的,其在頁面上的表現(xiàn)形式也隨之確定。
沒有所見即所得當(dāng)然有點(diǎn)遺憾,但對(duì)我來說,這已經(jīng)足夠了,因?yàn)榘呀M件的Value和后臺(tái)Javabean的屬性進(jìn)行簡單的綁定,我就得到了所有需要的程序行為。頁面顯示和后臺(tái)數(shù)據(jù)的同步、用戶輸入的轉(zhuǎn)換、數(shù)據(jù)的有效性驗(yàn)證、錯(cuò)誤信息的提示以及UI組件狀態(tài)的保存和恢復(fù),所有這一切不需要我寫任何代碼,JSF已經(jīng)代勞了。
JSF的另一個(gè)特色是它的數(shù)據(jù)組件。我曾經(jīng)很長時(shí)間使用PowerBuilder開發(fā)程序,熟悉PowerBuilder的程序員都知道,PowerBuilder最引人注目的是它的所謂數(shù)據(jù)窗口。并不好看的界面,笨拙的IDE,PowerBuilder單單憑借一個(gè)數(shù)據(jù)窗口,就吸引了大批程序員。PowerBuilder與數(shù)據(jù)庫是天生的一對(duì),長期使用PowerBuilder的結(jié)果,我養(yǎng)成了以數(shù)據(jù)庫為中心的設(shè)計(jì)習(xí)慣。
這個(gè)習(xí)慣一直保持到今天,幾乎成了我的嗜好,前面提到的126張表,就是最好的例子,換成別的程序員,也許30張表就夠了。
所以,JSF的數(shù)據(jù)組件讓我一見鐘情。數(shù)據(jù)組件實(shí)際上包括兩個(gè)組件,一個(gè)是UIData,一個(gè)是UIColumn。JSF將數(shù)據(jù)表看成是由若干個(gè)列組成的一個(gè)表格,而行的數(shù)目取決于數(shù)據(jù)源中數(shù)據(jù)的條數(shù)。這與PowerBuilder的數(shù)據(jù)窗口殊途同歸。當(dāng)然,數(shù)據(jù)組件不是直接從數(shù)據(jù)庫中取得數(shù)據(jù)(實(shí)際上,設(shè)計(jì)模式也不允許程序員這樣做),而是通過一個(gè)Javabean以resultSet的形式傳遞給數(shù)據(jù)組件。在JSP中,這樣的程序邏輯夠我折騰一陣的了,而在JSF中,這和生成一個(gè)文本輸入框一樣容易。
JSF數(shù)據(jù)組件的用途并不限于顯示數(shù)據(jù)庫表的內(nèi)容,實(shí)際上,所有實(shí)現(xiàn)了List接口的對(duì)象都可以成為數(shù)據(jù)組件的數(shù)據(jù)源,這給Java的Web編程帶來了極大的便利。而且,如果你想直接編輯數(shù)據(jù)表中的數(shù)據(jù),JSF也可以做到,只需以可讀可寫的方式,將UIColumn的value屬性和數(shù)據(jù)源中你想修改的屬性綁定在一起,用戶在網(wǎng)頁上所做的修改,就會(huì)自動(dòng)保存到數(shù)據(jù)源中。這樣的功能,在JSP中,程序員都要深吸一口氣才敢動(dòng)手的。我的第一個(gè)JSF程序,之所以能在一個(gè)月的時(shí)間內(nèi)完成346個(gè)頁面,數(shù)據(jù)組件功不可沒。
【編輯推薦】