未渲染的 p:dataTable 最终出现在 pe:exporter PDF 中



我有 2 个数据表:

<p:dataTable id="tbl1" var="prop1" value="#{bean.prop1}" rendered="#{bean.listP1.size() != 0}">
// ...
</p:dataTable>

<p:dataTable id="tbl2" var="prop2" value="#{bean.prop2}" rendered="#{bean.listP2.size() != 0}">
// ...
</p:dataTable>

在XHTML页面上,经过一些操作,我得到了正确的结果,具体取决于listP1listP2的大小。

我的问题是点击导出按钮

<h:commandLink>
<p:graphicImage value="/resources/icons/download.png" style="width : 35px; height:35px"/>
<pe:exporter type="pdf" target="tbl1, tbl2" fileName="SurveyResults"/>
</h:commandLink>

我得到了错误的结果:我得到了两张桌子而不是一张,因为其中一个是size = 0

你对解决这个问题有什么想法吗?

在版本 8 之前,pe:exporter不关心您提供的数据表是否呈现,请参阅 https://github.com/primefaces-extensions/primefaces-extensions.github.com/issues/757

如果您尚未使用版本 8,则可以使用 EL 为target属性创建动态值。例如:

<pe:exporter type="pdf"
target="#{empty bean.listP1 ? '' : 'tbl1'}#{empty bean.listP1 or empty bean.listP2 ? '' : ','}#{empty bean.listP2 ? '' : 'tbl2'}"
fileName="SurveyResults"/>

由于这些表达式有点毛茸茸的,你可能想在你的 bean 中创建一个方法,创建一个目标字符串并执行以下操作:

<pe:exporter type="pdf"
target="#{bean.exporterTargets}"
fileName="SurveyResults"/>

例如,在您的豆子中:

public String getExporterTargets() {
return Stream.of(listP1.isEmpty() ? null : "tbl1",
listP2.isEmpty() ? null : "tbl2")
.filter(Objects::nonNull)
.collect(Collectors.joining(","));
}

相关内容

  • 没有找到相关文章

最新更新