大家好我正在尝试使用自己的“导出”按钮创建多个表,我使用ui:repeat标签生成所有数据表,问题是我需要将表的ID放在dataexporter的目标中属性,因为在JSF中你无法动态生成ID我无法区分数据表,它们都具有相同的ID :(:
<ui:repeat var="location" value="#{locationOwner.locations}"
varStatus="status">
<h2>
Localidad:
<h:outputText value="#{location.name}" />
</h2>
<h:commandLink>
<p:graphicImage value="resources/images/excel.png" />
<h:outputLabel>Exportar</h:outputLabel>
<p:dataExporter type="xls" target="tablaExp"
fileName="pedidosEnDisponibilidad#{location.name}" />
</h:commandLink>
<p:dataTable id="tablaExp" var="storeRequest"
value="#{location.userRequests}">
<p:column>
<f:facet name="header">Nombre del cliente</f:facet>
<h:outputText value="#{storeRequest.clientName}" />
</p:column>
<p:column>
<f:facet name="header">Email del cliente</f:facet>
<h:outputText value="#{storeRequest.clientEmail}" />
</p:column>
<p:column>
<f:facet name="header">Número del cliente</f:facet>
<h:outputText value="#{storeRequest.clientNumber}" />
</p:column>
<p:column>
<f:facet name="header">Equipo</f:facet>
<h:outputText value="#{storeRequest.equipo.productName}" />
</p:column>
<p:column>
<f:facet name="header">Método de contacto</f:facet>
<h:outputText value="#{storeRequest.contactMethod}" />
</p:column>
<p:column>
<f:facet name="header">Fecha del pedido</f:facet>
<h:outputText value="#{storeRequest.requestedDate}" />
</p:column>
</p:dataTable>
</ui:repeat>
答案 0 :(得分:0)
我猜您可以使用<ui:repeat>
的“status”变量并使用索引。
例如:
<h:commandLink>
<p:dataExporter type="xls" target="tablaExp#{status.index}" ... />
</h:commandLink>
<p:dataTable id="tablaExp#{status.index}" ...>
有关详细信息,请参阅http://docs.oracle.com/javaee/6/javaserverfaces/2.1/docs/vdldocs/facelets/ui/repeat.html。