
默認情況下,每個視圖對象都有一個預定義的類別“默認”。 我創建了三個新類別“名稱”,“聯系人”,“其他”,并為其分配了屬性。 在此選項卡上,我們還可以為我們的類別定義標簽和工具提示。 在“應用程序模塊測試器”窗口中,它看起來像這樣:

根據文檔 , 動態表格和搜索表格應使用UI類別。 ADF Faces動態表單組件確實具有新的屬性Category 。 該表格過濾VO的屬性,僅顯示指定類別的屬性。 例如,如果我想顯示“ 名稱”類別的屬性,則可以使用以下構造:
<dynamic:form value="#{bindings.VEmployeesIterator}" id="f3" category="Name"/>
因此,如果我們要分別顯示不同的類別,則必須為每個類別使用<dynamic:form標記。 但是文檔提供了一個非常有趣的句子“ 對于動態表單,每個類別的屬性將出現在單獨的選項卡中 ”。 我想我們應該自己實現此功能:)。 在這篇文章中,我將展示我們如何做到這一點
在我的視圖對象的實現類中,我定義了一些API方法來獲取視圖對象的所有UI類別(默認類別除外):
public List<Category> getAttrCategries() {return getOrderedCategories(false, //except DefaultCategoryType.ATTRIBUTE, null); }
為了在頁面上為每個UI分類繪制選項卡,我使用了以下jspx代碼:
因此,在這種簡單的構造中,我在navgationPane中使用forEach標簽為每個類別繪制commandNavigationItem。 MainDynamicBean托管bean的Java代碼如下所示:
//Currently selected tabprivate String selectedItem;//Getting categories listpublic List<Category> getCategoryList() {return (List<Category>) resolveExpression("#{bindings.VEmployeesIterator.viewObject.attrCategries}");}//Just a setterpublic void setSelectedItem(String selectedItem) {this.selectedItem = selectedItem;}//Getting selected itempublic String getSelectedItem() {//If nothing is selected, then select the first oneif (selectedItem == null) {List<Category> l = getCategoryList();if (l.size()>0) selectedItem =? l.get(0).getName();??????????????? }??????? return selectedItem;}//Resolving EL expressionspublic static Object resolveExpression(String expression) {FacesContext facesContext =? FacesContext.getCurrentInstance();Application app = facesContext.getApplication();ExpressionFactory elFactory = app.getExpressionFactory();ELContext elContext = facesContext.getELContext();ValueExpression valueExp = elFactory.createValueExpression(elContext, expression, Object.class);return valueExp.getValue(elContext);}
最后,我使用以下構造繪制具有所選類別屬性的動態表單:
<dynamic:form value="#{bindings.VEmployeesIterator}" id="f2"binding="#{MainDynamicBean.dynform}"forceRefresh="#{MainDynamicBean.needRefresh}"/>
和適當的一段Java代碼:
private DynamicForm dynform;//Setterpublic void setDynform(DynamicForm dynform) {this.dynform = dynform;}//Getterpublic DynamicForm getDynform() {return dynform;}public Boolean getNeedRefresh() {//If selected category is not equal to dynform's category//then set needed category and refresh the dynamic formif (dynform.getCategory()!=getSelectedItem()) {this.dynform.setCategory(getSelectedItem()); return true;}else return false;????????????? }
作為我們工作的結果,我們得到了以下屏幕:



就這樣!
您可以下載此帖子的示例應用程序 。
參考:來自ADF實踐博客的JCG合作伙伴 Eugene Fedorenko的“ 動態使用UI類別”表單 。
翻譯自: https://www.javacodegeeks.com/2012/04/adf-using-ui-categories-with-dynamic.html