1

我需要在我的 DataTable 中获取排序/过滤列的名称。使用 ajax 事件“过滤器”,我得到过滤后的值和列名。对于排序,我使用了偶数“排序”,但找不到返回排序列名称的方法

<p:dataTable id="userTable" var="user" value="#{userController.lazyModel}"
             widgetVar="userTableVar" selection="#{userController.selectedUser}" 
             paginator="true" rows="#{userController.defaultRows}" paginatorPosition="bottom" rowSelectMode="checkbox"
             lazy="true"
             paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {PageLinks} {CurrentPageReport} {NextPageLink} {LastPageLink}"                                                             
             rowKey="#{user.userId}" rowsPerPageTemplate="#{userController.rowOptions}"
             emptyMessage="#{bundle.noRows}" >

    <p:ajax event="sort" listener="#{userController.onSort}"></p:ajax>
    <p:ajax event="filter" listener="#{userController.onFilter}"></p:ajax>

    <p:column selectionMode="multiple" style="width:16px;text-align:center"/>

    <p:column sortBy="#{user.username}"  filterBy="#{user.username}" style="width: 20%;" >
        <f:facet name="header" >
            <h:outputText value="Username"></h:outputText>
        </f:facet>
        <h:outputText value="#{user.username}"></h:outputText>
    </p:column>

    <p:column sortBy="#{user.userRight}"  filterBy="#{user.userRight}" style="width: 20%;" >
        <f:facet name="header" >
            <h:outputText value="Userright"></h:outputText>
        </f:facet>
        <h:outputText value="#{user.userRight}"></h:outputText>
    </p:column>


</p:dataTable>
public void onSort(SortEvent event) {
     System.out.println(event.isAscending() + " - "
                        + event.getSortColumnIndex() + " - "
                        + event.getSortColumn().getField());
}

public void onFilter(FilterEvent event) {
     System.out.println(event.getFilters());
}
4

1 回答 1

1

您需要fieldp:column.

文档中:

要通过惰性加载方法进行过滤和排序的字段名称。如果未指定,则filterBy/sortBy值用于标识字段名称。

然后event.getSortColumn().getField()会工作。

于 2019-10-25T07:41:45.767 回答