我有一个自定义的dataTable标记,我在所有视图中都使用它,它位于此处:src / main / webapp / WEB-INF / tags / custom_datatable.xhtml
我的问题是,如果我对一个或多个可过滤的列进行过滤,并使用dataExporter进行导出,则列过滤会丢失,因此导出将忽略这些其他过滤。我该如何更改?
这是自定义数据表标记的来源:
<ui:composition
xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://xmlns.jcp.org/jsf/facelets"
xmlns:h="http://xmlns.jcp.org/jsf/html"
xmlns:f="http://xmlns.jcp.org/jsf/core"
xmlns:p="http://primefaces.org/ui">
<script type="text/javascript">
$ = jQuery;
var scrollPos;
function saveScrollPos() {
scrollPos = $(".ui-datatable-scrollable-body").scrollTop();
}
function getScrollPos() {
$(".ui-datatable-scrollable-body").scrollTop(scrollPos);
}
</script>
<p:dataTable id="#{id}" value="#{value}" var="item" widgetVar="#{widgetVar}"
draggableColumns="true" filterDelay="1000"
styleClass="breakwords"
emptyMessage="#{bundle.EmptyMessage}" filteredValue="#{controller.filteredItems}"
selectionMode="single" selection="#{controller.selected}"
rowKey="#{item.id}"
rowStyleClass="#{rowStyleClass}"
sortBy="#{sortBy}" sortOrder="#{(sortOrder!=null)?sortOrder:'ascending'}"
scrollRows="30" scrollable="true" liveScroll="true" scrollHeight="400"
tableStyle="#{tableStyle}"
>
<p:ajax event="rowSelect" update="createButton viewButton editButton deleteButton"/>
<p:ajax event="rowUnselect" update="createButton viewButton editButton deleteButton"/>
<f:facet name="header">
<p:outputPanel >
<p:inputText id="globalFilter" style="width:150px" onkeyup="PF('#{widgetVar}').filter()" placeholder="Searching..."/>
<h:commandLink style="float:right">
<p:graphicImage name="/images/csv.png" width="24"/>
<p:dataExporter type="csv" target="#{id}" fileName="list"/>
</h:commandLink>
<h:commandLink style="float:right">
<p:graphicImage name="/images/excel.png" width="24"/>
<p:dataExporter type="xls" target="#{id}" fileName="list" />
</h:commandLink>
<p:commandButton icon="ui-icon-refresh" oncomplete="javascript:window.location.reload();" action="#{controller.refresh}" value="Refresh" style="float:left" />
<p:commandButton id="toggler" type="button" value="Oszlopok" style="float:left" icon="ui-icon-calculator" />
<p:columnToggler datasource="#{id}" trigger="toggler" >
<p:ajax event="toggle" listener="#{controller.getControllerDelegate().onToggle}" />
</p:columnToggler>
</p:outputPanel>
</f:facet>
<ui:insert />
</p:dataTable>
</ui:composition>
我的Primefaces版本:
<dependency>
<groupId>org.primefaces</groupId>
<artifactId>primefaces</artifactId>
<version>6.2</version>
<type>jar</type>
</dependency>
答案 0 :(得分:0)
PrimeFaces出口商应处理此问题。如果将数据表的后备bean值放在@RequestScoped
中,则可能导致此特定行为-触发导出时失去过滤器值。解决方案是将用于过滤的后备bean值和其他表属性放在@ViewScoped
下。