Primefaces DataTable无法正确排序

时间:2015-04-17 21:35:56

标签: java sorting primefaces character-encoding

我是Java EE webapp开发人员(spring,hibernate,jsf,primefaces),我发现了primefaces组件DataTable的问题。该问题涉及列排序,尤其是对具有特殊字符的单词进行排序。

在我的语言(捷克语)中,我们使用像(č,ř,ž等)这样的字符,以这些字符开头的单词在表的末尾排序。这就是问题所在。应在适当的字母后对它们进行分类,例如“č”应该在“c”之后,“ř”应该在“r”之后,而不是在没有特殊字符的所有记录之后。

我已经在使用Spring Framework提供的CharacterEncoding过滤器,它应该强制每个请求和响应的字符集(UTF-8)。但它并没有解决问题。以下是过滤器的配置:

<filter>
    <filter-name>charEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
        <param-name>forceEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>

有没有办法纠正这种行为?

1 个答案:

答案 0 :(得分:5)

我希望以编程方式这样做也会对你有用。 entities只是List<String>

<p:dataTable value="#{testBean.entities}" var="ent">
    <p:column headerText="..." sortBy="#{ent}" sortFunction="#{testBean.sort}">
        #{ent}
    </p:column>
</p:dataTable>

Bean方法:

public int sort(Object ent1, Object ent2) {
    String s1 = (String) ent1;
    String s2 = (String) ent2;

    Collator collator = Collator.getInstance(new Locale("cs"));  //Your locale here
    collator.setStrength(Collator.IDENTICAL);
    return collator.compare(s1, s2);
}

Collator当然可以在bean上成为一个属性,可能会有点性能。

如果只是将上述sortBysortFunction移至p:datatable - 标记后的默认排序。