如何在primefaces数据表中显示可变数量的列

时间:2013-09-18 08:29:17

标签: jsf jsf-2 primefaces datatable

我有以下ArrayList

class Report{
private String manufacturer;
private String color;
private List<Double> revenue;
}

如何在primefaces数据表上显示它。我尝试使用p:列它不起作用。 我在XHTML页面上有以下代码

<p:dataTable value="#{tableBean.reportList}" var="report" id="table">

    <p:column headerText="Manufacturer">#{report.manufacturer}</p:column>

     <p:column headerText="Color">#{report.color}</p:column>
 </p:dataTable >

我也试过p:columns和ui:repeat。但我无法达到理想的输出。结果

<p:columns var="amount" value="#{report.revenue}">#{amount}</p:columns>

<ui:repeat var="amount" value="#{report.revenue}">
<p:column headerText="Revenue">#{amount}</p:column>
</ui:repeat>

我需要输出作为包含制造商名称,颜色和所有收入的表格

2 个答案:

答案 0 :(得分:3)

你的错误是你引用了当前迭代的行(<p:dataTable var>后面的对象为<p:columns value>。这是不可能的。列的数量不能根据当前迭代的行而变化。它只能可以在表格范围内设置。<p:columns value>应该引用支持bean中的属性。对于一个真实世界的示例,请参阅此答案:Creating and populating a DataTable dynamically in JSF2.0

在您的特定情况下,您基本上只想使用内部的<ui:repeat> <p:column>

<p:dataTable value="#{tableBean.reportList}" var="report">
    <p:column>
        #{report.manufacturer}
    </p:column>
    <p:column>
        #{report.color}
    </p:column>
    <p:column>
        <ui:repeat value="#{report.revenue}" var="revenue">#{revenue}</ui:repeat>
    </p:column>
</p:dataTable>

(如果您想在单独的行中打印它们,请在<br/>之后打印#{revenue};或者如果您想以逗号分隔打印它们,请使用varStatus)< / em>的

或者可能是嵌套表:

    <p:column>
        <h:dataTable value="#{report.revenue}" var="revenue">#{revenue}</h:dataTable>
    </p:column>

答案 1 :(得分:2)

尝试

<p:column headerText="Manufacturer">#{report.manufacturer}</p:column>

<p:column headerText="Color">#{report.color}</p:column>

<p:columns value="#{tableBean.columns}" var="column">
    <f:facet name="header">
        #{column.header}
    </f:facet>
    #{report.revenue.get(column.property)}
</p:columns>

bean列中的位置是:

List<ColumnModel> columns;

static public class ColumnModel implements Serializable {

    private String header;
    private int property;

    public ColumnModel(String header, int property) {
        this.header = header;
        this.property = property;
    }

    public String getHeader() {
        return header;
    }

    public int getProperty() {
        return property;
    }
}

填写如下:

for(int i = 0; i < TOTAL_NUMBER_OF_REVENUES; i++){
    ColumnModel col = new ColumnModel("Revenue "+i, i);
    columns.add(col);
}

来源:http://www.primefaces.org/showcase/ui/datatableDynamicColumns.jsf