3

我有一个这样的数据表。但它不会将标题导出到 excel :

<h:form id="formOptionList">
<p:dataTable id="OptionTable"
             var="Options"
             widgetVar="OptionTable"
             value="#{managedBean.options}"
             filteredValue="#{managedBean.filteredOptions}"
             emptyMessage="No  Options found."
             rendered="#{managedBean.userPreferences.showTable}"
             paginator="true"
             rows="10"
             paginatorTemplate="{FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
             rowsPerPageTemplate="20,50,100"
             >

<p:column id="id" headerText="ID" filterBy="id" filterMatchMode="exact" width="12%" rendered="#{managedBean.userPreferences.showID}" >
        <h:outputText value="#{options.optionID}" />
</p:column>
....
....

</p:dataTable>

<h:panelGrid columns="1">
    <p:panel header="Export All Data">
        <h:commandLink>
            <p:graphicImage value="../resources/images/menuicons/options.png" />
            <p:dataExporter type="xls" target="OptionTable" fileName="Options" />
        </h:commandLink>
    </p:panel>
</h:panelGrid>

 </h:form>  

所以我把它改成了

 <p:column id="id" filterBy="id" filterMatchMode="exact" width="12%" rendered="#{managedBean.userPreferences.showID}" >
    <f:facet name="header>">
        <h:outputText value="Option ID"/>
   </f:facet>
   <h:outputText value="#{Options.OptionID}" /> 
</p:column>

而且我仍然看不到 excel 文件中的标题。有任何想法吗 ?

从 primefaces 数据表导出的 excel 文件中未显示标题

4

3 回答 3

2

尝试这个:

<p:column id="id" filterBy="#{Options.OptionID}" filterMatchMode="exact" width="12%" rendered="#{managedBean.userPreferences.showID}" >
    <f:facet name="header>">
        <h:outputText value="Option ID"/>
    </f:facet>
    <h:outputText value="#{Options.OptionID}" /> 
</p:column>
于 2015-03-10T11:59:44.510 回答
1

<h:outputText value= ""/>在你的</f:facet>?

<p:column>
    <f:facet name="header">
        <h:outputText value="Your Column Name" />
    </f:facet>
    <h:outputText value="Your value" />
</p:column> 
于 2013-11-18T18:38:56.800 回答
0

您可以放置​​一个不显示的新列,从现有列中放置一个导出器 false

<p:column id="id" filterBy="# Options.OptionID}"filterMatchMode="exact" width="12%" rendered="#anagedBean.userPreferences.showID}"exporter="false">
        <f:facet name="header>">
                    <h:outputText value="Option ID" />
        </f:facet>
                <h:outputText value="#{Options.OptionID}" />
</p:column>

添加不显示的新列并删除所有排序、过滤和渲染

<p:column exporter="true" style="display:none;">
    <f:facet name="header>">
        <h:outputText value="Option ID"/>
   </f:facet>
   <h:outputText value="#{Options.OptionID}" /> 
  </p:column>

这完美地工作。

于 2016-06-08T14:22:07.977 回答