Seam全稱是Jboss Seam,是一個Java EE 5框架。JSF是一種標准的 J2EE 表示層的技術,其主旨是為了使 Java 開發人員能夠快速的開發基於 Java 的 Web 應用程序。
1. 異常處理問題
請為JSF加入Seam框架,看看Seam框架 - 無縫集成JSF,共三部分,裡面告訴了你怎麼在servlet容器下配合spring使用Seam,Seam不是一定要在ejb3和jboss下才可以使用。因為單獨使用JSF的話她的異常處理功能很簡陋,跟蹤不到你想看的地方,對於開發很不方便,你只有打開日志才能看到問題所在,而Seam在加入 phase-listener以後,對JSF不同的生命周期都進行了功能增強,即使不使用Seam任何的功能,她也能毫無保留的輸出所有的異常棧。
2.CSS問題
如果你想在你的項目中使用JSF,CSS太重要了,很多剛開始使用JSF的人都不是很習慣JSF基於塊結構開發頁面,因為JSF讓你注意的是內容展現的結構,而不是內容展現的樣式,這是完全符合w3開發Html的初衷,大家使用< td>來做頁面展現布局,其實是錯誤已久的方法,如果在JSF中能了解如何使用CSS進行布局,JSF不適合復雜頁面設計這句話就不攻自破了。
3. 細心的使用dataTable組件
數據列表是最常用的頁面組件,但是我毫不留情的說JSF的dataTable組件的實現簡直太濫了,它就是 JSF 開發一大禍根。沒有很方便的解決特定行樣式顯示的問題,沒有解決回退按鈕風險問題,沒有dataScroll和dataTable組件進行數據庫分頁的優雅辦法,數據提交的幻影問題,我的開發很多時間用在了dataTable的和其他組件塊融合上面。不過JSF1.2通過統一el,加入了對JStl的 foreach標記的支持,我雖然還沒有使用,但是我認為這有可能成為數據列表開發的一個有力補充。
4.建議把JSF的模型bean和後台的業務bean合二為一
這樣可以在前端提交頁面與模型綁定的同時,完成業務bean的數據封裝,並且交由服務層處理一氣呵成。這樣做有個好處,就是我們會想方設法通過各種手段在第一時間就完成模型bean對業務bean的封裝,消除服務層對dto的依賴。這樣是可行的,因為JSF的頁面綁定機制提供了很好的幫助。
5.請考慮多的使用convert組件
比如列表頁面有個radio塊,提交radio值就是一個int數值,然後在展現邏輯去恢復這個radio 值對應的業務模型,這樣增加了展現邏輯處理頁面數據的負擔,而且不好管理,如果把這個工作放在自定義的convert中,讓convert在頁面上顯示 int數值,在提交上尋找對象,那麼頁面和服務層就屏蔽了這樣的工作,看到的都是對象的進出。
6.用了myfaces的組件
我使用了myfaces一個自己的組件,就是跨頁面專遞參數,非常好用,剛使用JSF的朋友,可以看到跳轉的下一個頁面用它怎麼做,但是建議傳遞模型對象,不要傳遞數值,你使用JSF就是因為她是基於對象考慮頁面設計的。
7. 小心使用session來處理JSF
JSF過多的使用了session,但是我可以肯定一點,展現層一定是需要基於狀態的方式來做的,這樣可以簡化開發,無狀態的方式會帶來更多的無序代碼。不是每個人都是高手。可以考慮使用Seam的conversation來處理,她的長會話特別適合業務編輯,默認的短會話會填補JSF有時容易丟失的短期數據。
8.調試JSF的問題
有時你使用JSF想知道你的數據在哪個階段變化了,你不會把JSF代碼加入到自己的工程中來調試把,請加入自定義的phaseListener,繼承phaseListener這個接口,你可以在把你的程序設置在任何階段跳出來進行調試。
9. 分頁的問題
在google搜一下,有個http://www.blogJava.Net/steady/archive/2005/12 /30/26013.ASPx提供了分頁的方式,我就在使用,這是目前最可能的方式了把,呵呵,不過要注意她使dataTable的values直接使用了dataModel,她與Seam的@dataModel是不兼容的,所以不能使用Seam的@dataModel功能,需要使用get方式了。
10.如果想使用ajax4JSF等AJax框架,你需要使用facelet,讓頁面成為標准的xHtml,記好了,不要寫了一大堆才發現這個問題。
11. 如果你在dataTable列表頁面使用了radio的話,
你還想在列表上做一些link操作,一定要在操作上加入immediate= true,否則在沒有選擇radio的情況下她是不會讓你過去的。並且列表中要使用selectBooleanRadio,而不是 selectOneRadio或者selectManyRadio。checkbox也是一樣。
12.對於doGet的方式請使用Seam的組件。
13. 如果你導入了其他頁面,而沒有使用facelet的話,那麼導入的那個頁面就要完全符合JSF組件的渲染方式,混合Html會解析不出來。
反過來在主頁面應該盡量多使用JSF標記與html混合的方式,這樣可以使開發變得簡單,盡管有時候JSF會很丟丑,你試試每個html組件都有個 render屬性就知道了。JSF1.2已經把混合的html作為一個output組件來輸出,可以和JSF組件兼容,是件好事。對於混合Html這種方式,我想說你關注的是JSF組件和模型的關系,而不一定頁面都得是JSF組件標記。
14.不要相信JSF運行的速度慢
JSF雖然在樹形組件處理上,每一個階段都經歷了遞歸遍歷,但是要相信JSF依然很快,我現在的系統很快,如果你使用後很慢那是項目產生了問題,而不是框架的產生了問題。
希望通過本文的介紹,能夠給你帶來幫助。