我有以下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>
我需要输出作为包含制造商名称,颜色和所有收入的表格
答案 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