4

我有一个 PrimeFaces 3.2 DataTable 使用 apache myfaces 2.0.2 。我想要一个初始排序。我的 JSF 看起来像:

<p:dataTable  id="serverdata" var="serverdata" sortBy="#{serverdata[0]}" sortOrder="descending" 
                value="#{ serverDataTable.list }" rows="10" editable="true" 
                paginator="true" rowsPerPageTemplate="10,20,50"
                paginatorTemplate="{CurrentPageReport}  {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}">
                <f:facet name="header">  
                   Datatable
                 </f:facet>
                <p:column>
                    <f:facet name="header">
                        <h:outputText value="Datum"/>
                    </f:facet>
                    <h:outputText value="#{serverdata[0]}">
                    </h:outputText>
                </p:column>

但是UnsupportedOperationException: The result list is read-only.当我删除其中的 sortBy 标记时,我得到了一个正常工作。

所以我的问题是:我怎样才能实现初始排序?

4

1 回答 1

4

排序是在原始文件上执行的List。如果它是只读的,则会抛出异常。尝试相同的方法,但使用常规的、可变的List

编辑:在 bean 中创建一个常规列表:

public class MyBean {
...
List<MyObject> myList = new ArryList<MyObject>();
myList.add(new MyObject("a"));
myList.add(new MyObject("b"));
myList.add(new MyObject("c"));
...

然后使用这样的排序:value="#{myBean.myList}" var="myVar" sortBy="#{myVar.stringProp}"

EDIT2:如果排序参数是字符串或数字,则不需要自定义任何内容。如果您要对其他任何内容进行排序,则必须定义一个自定义 sortFunction,

如果您使用延迟加载等高级选项(顺便说一句,它在 pf 3.2 中被破坏 - 您现在可以更新到 3.3 - 它已在 29.5 上发布并声称已解决此问题),您将必须定义一个自定义模型,照顾过滤和排序自己。

因此,如果您想按数组的内容对数据进行排序,则需要定义属性sortFunction="#{myBean.sortData()}"

于 2012-06-01T10:51:12.290 回答