gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-05 01:07:13 24 4
gpt4 key购买 nike

我有以下 ArrayList

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> 后面的对象为 <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 )

或者可能是一个嵌套表:
    <p:column>
<h:dataTable value="#{report.revenue}" var="revenue">#{revenue}</h:dataTable>
</p:column>

关于jsf - 如何在primefaces数据表中显示可变数量的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18867345/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com