0

我使用 Primefaces 3.5 创建带有过滤器的数据表。

<h:form id="table">
     <div class="showRuleStyle">            
        <p:dataTable id="RuleTable" var="e" value="#{ruleListBean.rules}" filteredValue="#{ruleListBean.filteredRules}" styleClass="ruleTable"  paginator="true" paginatorPosition="bottom" rows="15" emptyMessage="Keine Einträge gefunden.">

            <p:column id="companyColumn" headerText="Name" filterBy="#{e.name}" filterOptions="#{ruleListBean.filterNameOptions}" >
                <h:outputText value="#{e.name}"></h:outputText>
            </p:column>

            ...

            <p:column>
                <f:facet name="header"></f:facet>
                <h:commandButton id="DeleteRuleButton" value="Löschen" styleClass="buttondefault" action="#{ruleListBean.removeRule(e)}" update=":table"></h:commandButton>
            </p:column>
        </p:dataTable>
    </div>
</h:form>

现在,我按预期获得了表格,并且可以选择一个更新表格的过滤器。但是现在,如果我尝试选择不同的过滤器或选择空过滤器,则不会发生任何事情。如果我单击该按钮,它会再次起作用,我认为这是因为表单的更新。

我试图添加

 <p:ajax event="filter" update=":table"> 

和其他事件,但它不会工作。

有什么建议么?

问候亚历克斯

4

1 回答 1

0

ruleListBean 的范围是什么?我已经尝试了您的代码,它按预期工作(没有 p:ajax)。

我的 ruleListBean 在视图范围内。

建议使用比请求更长的范围,例如 viewscope 来保留filteredValue,以便过滤后的列表仍然可以访问。(PrimeFaces 用户指南第 135 页)

注意:将 h:commandButton 更改为 p:commandButton 以便您可以使用更新功能。

于 2013-09-12T21:30:37.907 回答