資源描述:
《Ajax只是過(guò)渡???》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫(kù)。
1、1前言 在J2EE下一代規(guī)范JavaEE5.0中,JSF(JavaServerFaces)技術(shù)被放到了一個(gè)非常重要的地位。J2EE社區(qū)試圖通過(guò)JSF來(lái)統(tǒng)一Web應(yīng)用的開發(fā)模式與方法。相對(duì)于傳統(tǒng)的基于JSP/Servlet的開發(fā)模型,JSF能夠帶來(lái)許多好處,譬如: ·可定制的豐富的UI組件 ·良好的事件響應(yīng)機(jī)制 ·表達(dá)式語(yǔ)言(ExpressionLanguage) ·表單數(shù)據(jù)的自動(dòng)轉(zhuǎn)換與驗(yàn)證 ·基于MVC的框架模型等等... 但同時(shí)我們也不得不看到,業(yè)界常見的JSF引擎普遍存在著一些缺陷與不足(并不是說(shuō)JSF技術(shù)模型本身的局限,而是常規(guī)的實(shí)現(xiàn)機(jī)制所產(chǎn)生的一些問(wèn)題),而這
2、些不足將可能對(duì)JSF成為日后Web應(yīng)用主流開發(fā)技術(shù)帶來(lái)一定的負(fù)面影響,包括: ·常規(guī)的JSF實(shí)現(xiàn)機(jī)制,運(yùn)行期性能并不是非常理想 ·缺少良好的工具支持 作為JCP組織成員,金蝶中間件對(duì)待JSF技術(shù)又是如何思考的?是否打算對(duì)JSF進(jìn)行全面支持?又是通過(guò)怎樣的解決方案來(lái)克服上述不足的呢?2JSF與Ajax 一談到Web開發(fā)技術(shù),就不得不提Ajax。這是目前在整個(gè)IT界都紅得發(fā)紫的概念了。在這里我想沒(méi)必要再去闡述一遍什么是Ajax,但我們可以對(duì)Ajax有一個(gè)基本的認(rèn)識(shí)?!jax其實(shí)是一種新瓶裝舊酒的技術(shù),它的好處是通過(guò)JavaScript與DHTML,提供了一種異步編程模型,從而
3、使我們的Web應(yīng)用給客戶帶來(lái)更好的人機(jī)體驗(yàn)。但Ajax解決問(wèn)題的層面很低;或者說(shuō),它解決問(wèn)題的方法與手段,很難形成一種可高度抽象的框架級(jí)解決方案,而JSF則是一種可擴(kuò)展的框架級(jí)解決方案?!∈聦?shí)上,我認(rèn)為Ajax是一種過(guò)渡技術(shù),相信在未來(lái)一到兩年之內(nèi)將被新的技術(shù)所代替,是微軟的XAML、Mozilla的XUL、還是任何可能的RIA標(biāo)準(zhǔn),實(shí)際上整個(gè)業(yè)界都在觀望。但不管采用什么技術(shù),JSF都能適應(yīng),對(duì)JSF來(lái)說(shuō)適應(yīng)一個(gè)新技術(shù)只是更換一個(gè)RenderKit而已。舉一個(gè)例子,如果想在網(wǎng)頁(yè)中實(shí)現(xiàn)圖表功能(Chart),MSIE有VML,Gecko和Opera有SVG,而在服務(wù)器端只需要簡(jiǎn)單
4、地判斷一下瀏覽器類型就可以選擇一個(gè)RenderKit生成不同的markup來(lái)完成相同的功能,這是用常規(guī)JSP技術(shù)很難完成的任務(wù)。3ApusicJSF:中國(guó)人做出的JSF引擎3.1容器級(jí)別的Ajax支持 目前有JSF+Ajax這種思路的,恐怕也不是金蝶中間件一家,但很多第三方的JSF+Ajax實(shí)現(xiàn)是提供一個(gè)組件庫(kù)以及一個(gè)附加的Servlet或Filter來(lái)處理Ajax請(qǐng)求,而我們是直接由JSF容器來(lái)處理Ajax請(qǐng)求的。我們會(huì)根據(jù)請(qǐng)求的類型來(lái)判斷這是一個(gè)正常的HTTP請(qǐng)求還是一個(gè)Ajax請(qǐng)求。如果是一個(gè)常規(guī)HTTP請(qǐng)求就運(yùn)行JSP頁(yè)面,生成頁(yè)面文檔(并且我們會(huì)在生成的頁(yè)面文檔中嵌入
5、Ajax所必須的JavaScript代碼,后文提及);如果該請(qǐng)求是一個(gè)Ajax請(qǐng)求,服務(wù)器對(duì)請(qǐng)求參數(shù)正常解碼,并執(zhí)行JSF中除頁(yè)面輸出階段以外的所有其他階段,這時(shí)將生成一個(gè)JSF的組件樹,遍歷該組件樹,從中找出發(fā)生變化的數(shù)據(jù),并將這些數(shù)據(jù)打包成一個(gè)Ajax應(yīng)答,并由客戶端來(lái)更新這些修改的數(shù)據(jù),甚至改變頁(yè)面外觀。 在JSF規(guī)范中,JSF頁(yè)面輸出階段所采用的RenderKit是可替換的,默認(rèn)的HTML_BASICRenderKit輸出的是標(biāo)準(zhǔn)的HTML語(yǔ)法,不包含任何JavaScript代碼,ApusicJSF引擎實(shí)現(xiàn)了一個(gè)AJAXRenderKit,可以在HTML文檔中嵌入Jav
6、aScript代碼來(lái)實(shí)現(xiàn)Ajax特性,而替換RenderKit只需要修改配置文件即可。那么,這樣能夠帶來(lái)怎樣的好處呢?3.2提升JSF運(yùn)行性能,帶來(lái)更好的人機(jī)體驗(yàn)。 常規(guī)JSF容器在狀態(tài)維護(hù)方面的通用做法是:基于Session的,或者基于請(qǐng)求傳遞型的,這就意味著,當(dāng)每進(jìn)行一次客戶端與服務(wù)器端的響應(yīng)時(shí),都需要把所有的狀態(tài)傳來(lái)傳去,這無(wú)疑會(huì)對(duì)系統(tǒng)的運(yùn)行性能帶來(lái)較大的負(fù)面影響,從而使開發(fā)人員誤以為:JSF是一種重量級(jí)的技術(shù)模型?!《ㄟ^(guò)ApusicJSF的Ajax特性,我們能夠只把發(fā)生變化的數(shù)據(jù)打包成Ajax請(qǐng)求發(fā)送給服務(wù)器端,而服務(wù)器端也只會(huì)將發(fā)生變化的數(shù)據(jù)打包成Ajax應(yīng)答,從而
7、大大提升系統(tǒng)的運(yùn)行效率。并且,傳統(tǒng)的JSF請(qǐng)求應(yīng)答將刷新整個(gè)頁(yè)面,而ApusicJSF將只更新發(fā)生變化的客戶端組件,從而給客戶帶來(lái)更好的人機(jī)體驗(yàn)。3.3簡(jiǎn)化Ajax的開發(fā) 以前要寫Ajax應(yīng)用要寫很多JavaScript代碼,開發(fā)、調(diào)試、維護(hù)這些Script腳本都相當(dāng)煩瑣,如果采用ApusicJSF技術(shù),你不再需要編寫任何JavaScript代碼,引擎已經(jīng)幫你生成了這些代碼。ApusicJSF所有的標(biāo)準(zhǔn)組件都是支持Ajax的,某些第三方組件可能本身并不支持Ajax,但使用一個(gè)名為