我需要您帮助在关闭Dialog
时刷新dataTable
组件。我尝试了很多方法来刷新dataTable
,但它不会检索更新的记录,除非我通过单击地址栏中 URL 旁边的"Go"按钮刷新了整个页面。
xhtml代码:
<h:form id="Requests">
<h:panelGroup id="table">
<p:fieldset id="Pendings" legend="Pending Requests">
<div id="refresh">
<p:dataTable id="PendingRequests" var="hr" value="#{hrd.pendingRequests}" paginator="true" rows="15" paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}" rowsPerPageTemplate="5,10,15" paginatorPosition="bottom" filteredValue="#{hrd.filteredPendingRequests}">
<p:column headerText="Req. Date" sortBy="#{hr.requestDate}" filterMatchMode="contains" filterBy="#{hr.requestDate}" >
<h:outputText value="#{hr.requestDate}"/>
</p:column>
<p:column>
<f:facet name="header">View</f:facet>
<p:commandButton id="submitbutton" update=":Requests:#{hr.dialogueName} "
oncomplete="PF('#{hr.certificateDialogue}').show()" icon="ui-icon-search" title="View">
<f:setPropertyActionListener value="#{hr}" target="#{hrd.selectedRequest}"/>
</p:commandButton>
</p:column>
</p:dataTable>
</div>
</p:fieldset>
</h:panelGroup>
<p:dialog id="CertificateDialog" header="Cert1" widgetVar="CertificateDialog" >
<p:ajax event="close" update=":Requests" listener="#{hrd.UpdateDatatable}"/>
</p:dialog>
</h:form>
我尝试仅更新数据表,但它不刷新。虽然,我尝试使用 @form 和 @all 更新完整表单,但 dataTable 再次没有刷新。
更新数据表方法:
public void UpdateDatatable(CloseEvent event) {
RequestContext.getCurrentInstance().update(":Requests");
}
当您尝试使用 RequestContext.update()
从ManagedBean
更新组件时,不应使用相对组件 id,因为您没有任何关联。
要解决问题,请在侦听器中Requests
之前删除:
。
RequestContext.getCurrentInstance().update("Requests");
如果您觉得从受管理的 Bean 更新组件会增加内聚力。你可以使用一个p:remoteCommand
可以随时从你的javascript调用if。
<p:remoteCommand name="updateTable" process="@this" partialSubmit="true" update=":Results" />
您可以从javascript调用上述remoteCommand
,或者在您的情况下从对话框中调用,如下所示:
<p:dialog onhide="updateTable()">
...
</pdialog>
我的建议是将p:dialog
移出放置dataTable
的h:form
。因为将来,如果您需要在p:dialog
仍处于打开状态时更新h:form
,则更新放置p:dialog
的自己的h:form
将导致对话框p:dialog
突然关闭。
如果你的p:dialog
h:form
那么你可能不需要UpdateDatatable()
侦听器本身。 p:ajax
update
会为您完成这项工作。