2

在这里,我在 primeFaces 中为我的表使用 dataExporter,它在 type="xls" 中成功导出,但问题是另外我使用 columnToggler 来选择列,我只想将这些列作为导出 xls 文件的目标,这些在 columnToggler 中被选中/选择,例如: 在此处输入图像描述

这是我的 dataExporter 的代码,它针对我的表(id =“tbl”)。

    <h:commandLink>
  <img src="Resources/images/excel.png"/>
   <p:dataExporter type="xls" target="tbl" fileName="dailyPoolReport_#{userAuthorization.user.loginName}" pageOnly="false" postProcessor="#{customizedDocumentsView.postProcessXLS}"/>
   </h:commandLink>

这是我使用 columnToggler 的表格代码:

 <p:dataTable id="tbl" var="car" value="#{dailyTrackingBean.trackReportData}" rowIndexVar="row" style="font-size:12px; margin-bottom:0;"
                                                 paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
                                                 rowKey="#{car.vehicle.regNo}"
                                                 paginator="true" rows="50" rowsPerPageTemplate="50,100,500,1000,5000">


<f:facet name="header" >
 <h:outputText value="Vehicle Tracking Summary Report" style="font-size: 14px"/>

   <p:commandButton id="toggler" type="button" value="Columns" style="float:right;height: 22px;font-size: 11px" icon="ui-icon-calculator" />
<p:columnToggler datasource="tbl" trigger="toggler" >

  </p:columnToggler>

 </f:facet>

有什么可能的解决方案吗?

4

1 回答 1

7

为此,您可以使用与此类似的内容: http ://blog.primefaces.org/?p=3341

因此,您可以拥有一个布尔值列表,该列表代表属性“可见”的工具,并且可以将其用于“可导出”

前任:

<f:facet name="header">
   List of Cars
   <p:commandButton id="toggler" type="button" value="Columns"  style="float:right" icon="ui-icon-calculator" />
   <p:columnToggler datasource="cars" trigger="toggler">
     <p:ajax event="toggle" listener="#{dtBasicView.onToggle}" />
   </p:columnToggler>
</f:facet>



 <p:column headerText="Id" visible="#{dtBasicView.list[0]}" exportable="#{dtBasicView.list[0]}">
                   <h:outputText value="#{car.id}" />
 </p:column>

另一个加分 - 如果你使用上面的也回避:
* 问题(columntoggler 和分页)
* 问题(columntoggler 和 globalfilter)

希望它可以帮助你:)

于 2016-08-12T01:19:32.767 回答