編寫(xiě)自己的Component的步驟:
1、繼承一些類(lèi)或?qū)崿F(xiàn)一些接口
比如UIComponentBase, Render, Converter, Validator等;
比如例子中的UIInputDate,就需要擴(kuò)展UIInput,先定義Family和Type,并在構(gòu)造函數(shù)中指定Render為null(因?yàn)椴恍枰猂ender,而是component自己實(shí)現(xiàn)),編寫(xiě)encodeBegin和decode方法(在這里,encode是指將JSF的component編碼為HTML,而decode是指用HTML中的值更新component的properties);因?yàn)樾枰4鏍顟B(tài),所以編寫(xiě)saveState和restoreState方法;
2、在faces-config.xml中進(jìn)行配置;
3、編寫(xiě)Tag處理程序與JSP進(jìn)行整合(當(dāng)然,還有TLD文件)
以UIInputDate為例,需要繼承UICommonTag,先實(shí)現(xiàn)getComponentType和getRenderType;因?yàn)橐贘SP中保存component的狀態(tài),所以也要在tag中定義這些屬性,并實(shí)現(xiàn)setProperties方法,及release方法;編寫(xiě)驗(yàn)證TEI,實(shí)現(xiàn)isValid方法和isTrue方法
4、將所有這些打包package成jar文件,將faces-config.xml放在META-INF目錄中;
從前到后的順序分析自定義組件的調(diào)用過(guò)程
在JSF中自定義一個(gè)組件需要了解的概念很多,render, component,tag,這些概念之間又有相互重疊的概念部分,比如在component中有的屬性在tag中也需要有,如果更好的理解這些類(lèi)之間的協(xié)作過(guò)程,一個(gè)比較好的辦法就是從前端到后端的分析一個(gè)view被解析,并調(diào)用相應(yīng)render, component的過(guò)程。
比如,在JSP文件中有如下代碼:
很明顯,這是一個(gè)自定義組件,這些Tag需要有一個(gè)TagSupport類(lèi)來(lái)讀取這些數(shù)據(jù),這個(gè)類(lèi)就是Navigation_ToolbarTag。
這個(gè)Tag Support類(lèi)很重要,它起到一個(gè)連接JSP頁(yè)面與后端UIComponent的作用,怎么實(shí)現(xiàn)的? 主要通過(guò)幾個(gè)方法:
1、getComponentType(),通過(guò)這個(gè)方法,可以得知這個(gè)tag對(duì)應(yīng)的是哪個(gè)UIComponent;
2、getRendererType() 它返回一個(gè)字符串,表明用哪個(gè)Render來(lái)向客戶(hù)端呈現(xiàn)UIComponent;
3、setProperties(UIComponent component)一個(gè)很重要的方法,將tag中的屬性傳遞給UIComponent。
有了這三個(gè)方法,就可以基本實(shí)現(xiàn)將JSP與UIComponent整合在一起了。
然后,就是調(diào)用Render的encodingBegin,生成對(duì)應(yīng)的HTML代碼。
聯(lián)系客服