【发布时间】:2018-12-05 16:26:25
【问题描述】:
在下面的 index.xhtml 页面中,我有 3 个命令按钮,单击它们时会重定向到另一个包含数据表的.xhtml 页面,在完成时会对其进行过滤:
<ui:composition>
<h:form id="kpiForm">
<p:panel id="kpiPanel" >
<p:commandButton value="filter 1" action="/app/index" oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:1').click(); PF('wv').filter();" onclick="rc()" />
<p:commandButton value="filter 2" action="/app/index" oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:2').click(); PF('wv').filter();" onclick="rc()" />
<p:commandButton value="filter 3" action="/app/index" oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:3').click(); PF('wv').filter();" onclick="rc()" />
</p:panel>
<p:remoteCommand name="rc" actionListener="#{datatableController.clearAllFilters}" />
</h:form>
</ui:composition>
在另一个.xhtml 中有一个按钮,单击该按钮会清除应用于数据表的所有过滤器:
<!-- some code ommited -->
<ui:composition [...]>
<h:form id="OutsideFormID">
<p:panel id="MyPanelID" header="Some Title">
<p:commandButton value="Reset Table" onclick="PF('wv').clearFilters()" actionListener="#{datatableController.clearAllFilters}" update="MyDatatableID">
<p:resetInput target="MyDatatableID" />
</p:commandButton>
<p:dataTable id="MyDatatableID"
value="#{datatableController.items}"
rowKey="#{item.id}"
var="item"
selection="#{datatableController.selected}"
filteredValue="#{datatableController.filteredDemandas}"
widgetVar="wv">
<p:column id="MyColumnID" sortBy="#{item.status.statusName}" filterBy="#{item.status.statusName}" filterMatchMode="in" >
<f:facet name="header">
<h:outputText value="STATUS"/>
</f:facet>
<f:facet name="filter">
<p:selectCheckboxMenu id="BoxID" widgetVar="BoxWV" label="status" onchange="PF('wv').filter()">
<f:selectItems id="ComboID" value="#{datatableController.statusListCombo}" />
</p:selectCheckboxMenu>
</f:facet>
<h:outputText value="#{item.status.statusName}"/>
</p:column>
</p:dataTable>
</p:panel>
</h:form>
</ui:composition>
当我点击 filter 3 按钮时,包含数据表的 another.xhtml 被加载,完成后,数据表将按预期过滤。但是,如果我单击另一个过滤器按钮(例如 filter 2),之前应用的过滤器会保持活动状态,从而导致不需要的过滤;如果我再次单击其对应的过滤器按钮,则此以前应用的过滤器将被禁用。
我尝试使用remote command 调用 clearAllFilters 方法,但没有成功。
public void clearAllFilters() {
DataTable dataTable = (DataTable) FacesContext.getCurrentInstance().getViewRoot().findComponent("OutsideFormID:MyDatatableID");
if (!dataTable.getFilters().isEmpty()) {
dataTable.reset();
RequestContext requestContext = RequestContext.getCurrentInstance();
requestContext.update("OutsideFormID:MyDatatableID");
}
}
如何在每次单击任何过滤器按钮(在 kpiForm 中)时调用 clearAllFilters 方法,并且,在完成时,数据表将被过滤?
提前感谢您的帮助。
【问题讨论】:
标签: jquery ajax primefaces filtering