我是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>
有没有办法纠正这种行为?
答案 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上成为一个属性,可能会有点性能。
如果只是将上述sortBy
和sortFunction
移至p:datatable
- 标记后的默认排序。