作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下 ArrayList
class Report{
private String manufacturer;
private String color;
private List<Double> revenue;
}
<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 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/
我是一名优秀的程序员,十分优秀!