在primefaces中,dataTable Sort和Filter Not Preserved with Poll

时间:2013-07-16 11:31:19

标签: jsf sorting web primefaces polling

我一直试图在轮询更新表时保留排序和过滤。不幸的是,我无法做到这一点。

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

除非我遗漏了某些内容,否则我认为这是dataTable中的一个错误。

请看一下,如果这是错误,或者我的实施不正确,请告诉我。我一直试图让这个工作几天。任何帮助都会非常感激。

            <!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>

1 个答案:

答案 0 :(得分:0)

您可以尝试为您的dataTable提供ID,然后调用dataTableId.filter吗?它对我有用。

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