我目前的項(xiàng)目前端使用的是jsf+seam的架構(gòu),目前項(xiàng)目已經(jīng)進(jìn)入尾聲,我想把一些心得體會給大家說說,以便大家在使用jsf的時候,少走彎路。
1.異常處理問題:請為jsf加入seam框架,看看Seam - 無縫集成JSF,共三部分,里面告訴了你怎么在servlet容器下配合spring使用seam,seam不是一定要在ejb3和jboss下才可以使用。因?yàn)閱为?dú)使用jsf的話她的異常處理功能很簡陋,跟蹤不到你想看的地方,對于開發(fā)很不方便,你只有打開日志才能看到問題所在,而seam在加入phase-listener以后,對jsf不同的生命周期都進(jìn)行了功能增強(qiáng),即使不使用seam任何的功能,她也能毫無保留的輸出所有的異常棧。
2.css問題:如果你想在你的項(xiàng)目中使用jsf,css太重要了,很多剛開始使用jsf的人都不是很習(xí)慣jsf基于塊結(jié)構(gòu)開發(fā)頁面,因?yàn)閖sf讓你注意的是展現(xiàn)的內(nèi)容,而不是展現(xiàn)的樣式,這是完全符合w3開發(fā)html的初衷,大家使用<table><tr><td>來做頁面展現(xiàn)布局,其實(shí)是錯誤已久的方法,如果在jsf中能了解如何使用css進(jìn)行布局,jsf不適合復(fù)雜頁面設(shè)計這句話就不攻自破了。
3.細(xì)心的使用dataTable組件,數(shù)據(jù)列表是最常用的頁面組件,但是我毫不留情的說jsf的dataTable組件的實(shí)現(xiàn)簡直太濫了,它就是jsf開發(fā)一大禍根。沒有很方便的解決特定行樣式顯示的問題,沒有解決回退按鈕風(fēng)險問題,沒有dataScroll和dataTable組件進(jìn)行數(shù)據(jù)庫分頁的優(yōu)雅辦法,數(shù)據(jù)提交的幻影問題,我的開發(fā)很多時間用在了dataTable的和其他組件塊融合上面。不過jsf1.2通過統(tǒng)一el,加入了對jstl的foreach標(biāo)記的支持,我雖然還沒有使用,但是我認(rèn)為這有可能成為數(shù)據(jù)列表開發(fā)的一個有力補(bǔ)充。
4.建議把jsf的模型bean和后臺的業(yè)務(wù)bean合二為一,這樣可以在前端提交頁面與模型綁定的同時,完成業(yè)務(wù)bean的數(shù)據(jù)封裝,并且交由服務(wù)層處理一氣呵成。這樣做有個好處,就是我們會想方設(shè)法通過各種手段在第一時間就完成模型bean對業(yè)務(wù)bean的封裝,消除服務(wù)層對dto的依賴。這樣是可行的,因?yàn)閖sf的頁面綁定機(jī)制提供了很好的幫助。
5.請考慮多的使用convert組件,比如列表頁面有個radio塊,提交radio值就是一個int數(shù)值,然后在展現(xiàn)邏輯去恢復(fù)這個radio值對應(yīng)的業(yè)務(wù)模型,這樣增加了展現(xiàn)邏輯處理頁面數(shù)據(jù)的負(fù)擔(dān),而且不好管理,如果把這個工作放在自定義的convert中,讓convert在頁面上顯示int數(shù)值,在提交上尋找對象,那么頁面和服務(wù)層就屏蔽了這樣的工作,看到的都是對象的進(jìn)出。
6.我使用了myfaces一個自己的組件<t:updateListener>,就是跨頁面專遞參數(shù),非常好用,剛使用jsf的朋友,可以看到跳轉(zhuǎn)的下一個頁面用它怎么做,但是建議傳遞模型對象,不要傳遞數(shù)值,你使用jsf就是因?yàn)樗腔趯ο罂紤]頁面設(shè)計的。
7.小心使用session來處理jsf,jsf過多的使用了session,但是我可以肯定一點(diǎn),展現(xiàn)層一定是需要基于狀態(tài)的方式來做的,這樣可以簡化開發(fā),無狀態(tài)的方式會帶來更多的無序代碼。不是每個人都是高手。可以考慮使用seam的conversation來處理,她的長會話特別適合業(yè)務(wù)編輯,默認(rèn)的短會話會填補(bǔ)jsf有時容易丟失的短期數(shù)據(jù)。
8.調(diào)試jsf的問題:有時你使用jsf想知道你的數(shù)據(jù)在哪個階段變化了,你不會把jsf代碼加入到自己的工程中來調(diào)試把,請加入自定義的phaseListener,繼承phaseListener這個接口,你可以在把你的程序設(shè)置在任何階段跳出來進(jìn)行調(diào)試。
9.分頁的問題:在google搜一下,有個http://m.tkk7.com/steady/archive/2005/12/30/26013.aspx提供了分頁的方式,我就在使用,這是目前最可能的方式了把,呵呵,不過要注意她使dataTable的values直接使用了dataModel,她與seam的@dataModel是不兼容的,所以不能使用seam的@dataModel功能,需要使用get方式了。
10.如果想使用ajax4jsf等ajax框架,你需要使用facelet,讓頁面成為標(biāo)準(zhǔn)的xhtml,記好了,不要寫了一大堆才發(fā)現(xiàn)這個問題。
11.如果你在dataTable列表頁面使用了radio的話,你還想在列表上做一些link操作,一定要在操作上加入immediate=true,否則在沒有選擇radio的情況下她是不會讓你過去的。并且列表中要使用selectOneRadio,如果使用checkbox就要使用selectBooleanCheckbox.組件。
12.對于doGet的方式請使用seam的<s:link>組件,<%=request.getContextPath() %>問題,提交引起的書簽問題都迎刃而解。
13.如果你導(dǎo)入了其他頁面,而沒有使用facelet的話,那么導(dǎo)入的那個頁面就要完全符合jsf組件的渲染方式,混合html會解析不出來。反過來在主頁面應(yīng)該盡量多使用jsf標(biāo)記與html混合的方式,這樣可以使開發(fā)變得簡單,盡管有時候jsf會很丟丑,你試試每個html組件都有個render屬性就知道了。jsf1.2已經(jīng)把混合的html作為一個output組件來輸出,可以和jsf組件兼容,是件好事。對于混合html這種方式,我想說你關(guān)注的是jsf組件和模型的關(guān)系,而不一定頁面都得是jsf組件標(biāo)記。
14.不要相信jsf運(yùn)行的速度慢,jsf雖然在樹形組件處理上,每一個階段都經(jīng)歷了遞歸遍歷,但是要相信jsf依然很快,我現(xiàn)在的系統(tǒng)很快,如果你使用后很慢那是項(xiàng)目產(chǎn)生了問題,而不是框架的產(chǎn)生了問題。
15.相信jsf一定是下一代表現(xiàn)層的王者,這很重要。
就這么多把,jsf的能多經(jīng)驗(yàn),我還在摸索當(dāng)中,有機(jī)會還會和大家交流
fangshun1980@hotmail.com