我有以下数组列表
class Report{
private String manufacturer;
private String color;
private List<Double> revenue;
}
如何将其显示在 primefaces 数据表上。我尝试使用 p:columns 它不起作用。
我在 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>
我需要以表格形式输出,其中包含制造商名称、颜色和所有收入
你的错误是你引用了当前迭代的行(后面的对象<p:dataTable var>
as <p:columns value>
。这不可能。列的数量不能根据当前迭代的行而变化。它只能在表范围内设置。这<p:columns value>
应该引用支持 bean 中的属性。对于现实世界的例子,另请参阅这个答案:在 JSF2.0 中动态创建和填充 DataTable https://stackoverflow.com/questions/13970285/creating-and-populating-a-datatable-dynamically-in-jsf2-0/13970491#13970491.
在您的特定情况下,您基本上只想使用<ui:repeat>
inside <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/>
after #{revenue}
;或者如果您想以逗号分隔打印它们,请使用varStatus
)
或者可能是一个嵌套表:
<p:column>
<h:dataTable value="#{report.revenue}" var="revenue">#{revenue}</h:dataTable>
</p:column>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)