在素数面数据表中,不保留轮询的排序和筛选



我一直在尝试在轮询更新表时保留排序和筛选。不幸的是,我没能做到这一点。

当通过轮询每隔两秒或任何间隔刷新dataTable时,过滤器值将被删除,并且当单击时,无论列标题被单击多少次,列都只按升序排序。此外,排序箭头始终显示为"降序"。

除非我遗漏了什么,否则我认为这是dataTable中的一个错误。

请看一看,如果这是一个bug,或者我的实现不正确,请告诉我。几天来,我一直在努力让它发挥作用。任何帮助都将不胜感激。

            <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
            <html xmlns="http://www.w3.org/1999/xhtml"
               xmlns:ui="http://java.sun.com/jsf/facelets"
               xmlns:h="http://java.sun.com/jsf/html"
               xmlns:f="http://java.sun.com/jsf/core"
               xmlns:p="http://primefaces.prime.com.tr/ui">
            <f:view contentType="text/html">
               <h:head>
               </h:head>
               <h:body>
                  <h:form id="pollForm">
                     <p:poll id="poll" widgetVar="pollVar" interval="2"
                        listener="#{tableBean.update}" async="true" autoStart="true" />
                  </h:form>
                  <h:form>
                     <p:outputPanel autoUpdate="true">
                        <p:dataTable var="car" value="#{tableBean.carsSmall}">
                           <f:facet name="header">  
                              Ajax Sorting  
                          </f:facet>
                           <p:column sortBy="#{car.model}">
                              <f:facet name="header">
                                 <h:outputText value="Model" />
                              </f:facet>
                              <h:outputText value="#{car.model}" />
                           </p:column>
                           <p:column sortBy="#{car.year}">
                              <f:facet name="header">
                                 <h:outputText value="Year" />
                              </f:facet>
                              <h:outputText value="#{car.year}" />
                           </p:column>
                           <p:column sortBy="#{car.manufacturer}" 
                              filterBy="#{car.manufacturer}">
                              <f:facet name="header">
                                 <h:outputText value="Manufacturer" />
                              </f:facet>
                              <h:outputText value="#{car.manufacturer}" />
                           </p:column>
                           <p:column sortBy="#{car.color}">
                              <f:facet name="header">
                                 <h:outputText value="Color" />
                              </f:facet>
                              <h:outputText value="#{car.color}" />
                           </p:column>
                        </p:dataTable>
                     </p:outputPanel>
                  </h:form>
               </h:body>
            </f:view>
            </html>

你能试着给你的dataTable一个Id,然后调用dataTableId.filter吗?它对我有用。

<p:poll id="pollAutoUpdate" interval="5" oncomplete="entityTable.filter()" autoStart="false" stop="true" widgetVar="myPoll" />

相关内容

  • 没有找到相关文章

最新更新