如何将 HashMap 显示为 DataTable

How to display HashMap as DataTable

我在 mybean 中有一个 HashMap:

private ArrayList<HashMap<String,Object>> searchResult;

我可以成功地将数据显示为 table:

<p:dataTable id="resultTable" var="result" value="#{myBean.searchResult}">
    <p:column headerText="Name">
        <h:outputText value="#{result.NAME}" />
    </p:column>
    <p:column headerText="Amount">
        <h:outputText value="#{result.AMOUNT}" />
    </p:column>
    <p:column headerText="Date1">
        <h:outputText value="#{result.DATE1}" />
    </p:column>
    <p:column headerText="Date2">
        <h:outputText value="#{result.DATE2}" />
    </p:column>
</p:dataTable>

问题是我不知道 HashMap 会有多少个键(DATE1,DATE2,... DATEN)。 如何创建一个包含所有值及其键的数据表 headers?

UPD. 与下面的答案中的 showcase about Cars 相比,不同之处在于,class Car 具有品牌、年份、颜色等属性,但在我的情况下,您在执行前不知道所有列。所以我稍微修改了一个例子。也许有人会发现我的解决方案很有用。

myForm.xhtml(与示例相同):

<p:dataTable id="searchResults" var="result" value="#{myBean.searchResult}">                    
    <p:columns value="#{myBean.columns}" var="column" columnIndexVar="colIndex">
        <f:facet name="header">
            <h:outputText value="#{column.header}" />
        </f:facet>
        <h:outputText value="#{result[column.property]}" />
    </p:columns>
</p:dataTable>

myBean.java(ColumnModel 与示例展示中的相同):

private ArrayList<HashMap<String,Object>> searchResult;
private List<ColumnModel> columns;

private void createColumns(ArrayList<String> selectedDates){
    columns = new ArrayList<ColumnModel>();   
    columns.add(new ColumnModel("Name", "NAME"));
    columns.add(new ColumnModel("Amount", "AMOUNT"));
    for (int i = 0; i < selectedDates.size(); i++) {
        columns.add(new ColumnModel(selectedDates.get(i), "DATE" + i));
    }
    setColumns(columns);
}

您可以使用 PrimeFaces ShowCase 中描述的 p:columns 组件:

<p:dataTable id="cars" var="car" value="#{dtColumnsView.cars}" widgetVar="carsTable" filteredValue="#{dtColumnsView.filteredCars}">                    
    <p:columns value="#{dtColumnsView.columns}" var="column" columnIndexVar="colIndex" sortBy="#{car[column.property]}" filterBy="#{car[column.property]}">
        <f:facet name="header">
            <h:outputText value="#{column.header}" />
        </f:facet>
        <h:outputText value="#{car[column.property]}" />
    </p:columns>
</p:dataTable>