0

我的 JSF 代码是这样的:

<p:dataTable var="result" value="#{timerConfigurationJobList.model}" rows="10"
                         paginator="true" paginatorPosition="bottom"
                         paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
                         rowsPerPageTemplate="10,20,50" id="approvalTable" lazy="true">           
                <p:column sortBy="#{result.jobId}">
                    <f:facet name="header">
                        <h:outputText value="#{msg['content.jobList.jobId']}"/>
                    </f:facet>
                </p:column >
 </p:dataTable>

我得到的结果是这样的:

'错误排序'

从图中可以看出:'123'高于'2'、'4'、'7'和'9'。我希望它在最后出现,以便它按“数字”排序。

我正在使用 Java 和 JSF 2。

编辑:在惰性模型中我发现了这个:

@Override
    public final List<T> load(int first, int pageSize, String sortField, SortOrder sortOrder,
            final Map<String, Object> filters) {

        Map<String, Sort> sorts = new HashMap<>();

        if (sortField != null) {
            if (sortOrder.equals(SortOrder.ASCENDING)) {
                sorts.put(sortField, Sort.ASC);
            } else if (sortOrder.equals(SortOrder.DESCENDING)) {
                sorts.put(sortField, Sort.DESC);
            }
            // unsorted can be ignored
        }
4

1 回答 1

0

有多种方法可以解决该问题:

  1. 更改@Kukeltje 提到的列类型。不确定是否要更改架构。
  2. 使用列的 sortFunction 属性提供自定义排序。
  3. 传递 JSF 组件的排序列表。
于 2017-04-07T23:36:04.900 回答