2

所以,我已经尝试了 3 天......首先,我发现 primefaces 有一个带有标签 p:columns 的错误,因为它的 sortFunction 要求一个属性而不是一个方法。所以,我找到了这个解决方案: here 然而,即使达到了方法,我也不知道我要对哪一列进行排序,因为我不确定它是否可以传递参数。任何人都可以帮忙吗?我在这里使用 primefaces 5.0。

这是我的数据表:

<p:dataTable value="#{categoryBean.categories}" var="category">
    <p:column sortBy="#{category.name}">
        <f:facet name="header">
            <h:outputText value="Category"></h:outputText>
        </f:facet>
        <h:outputText value="#{category.name}"></h:outputText>
    </p:column>
    <p:columns value="#{categoryBean.columns}" var="column" columnIndexVar="i" sortBy="#{category}" sortFunction="#{categoryBean.customOrder}">
        <f:facet name="header">
            <h:outputText value="#{column.header}">
            </h:outputText>
        </f:facet>
        <h:outputText value="#{category[column.property][i].sumGrade/category[column.property][i].countGrade}"></h:outputText>
    </p:columns>
</p:dataTable>

这是我的方法:

public MethodExpression getCustomOrder() {
        FacesContext context = FacesContext.getCurrentInstance();
        return context.getApplication().getExpressionFactory()
            .createMethodExpression(context.getELContext(), 
            "#{categoryBean.customSort}", Integer.class, 
            new Class[] { Object.class, Object.class });
}


public int customSort(Object val1, Object val2) {
    System.out.println("mySort" + val1 + "/" + val2);
    return 0;
}

所以,对象可以到达方法,但是,我需要知道如何传递参数或其他东西,这样我才能知道我指的是哪一列。感谢你们。

4

1 回答 1

1

<p:dataTable>有一个属性sortBysortOrder

例如

<p:dataTable id="table1" var="x" value="#{myBackingBean.myEntities}" sortBy="#{x.id}" sortOrder="descending">

...假设您的支持 bean 对象有一个.getId()字段。

于 2014-05-14T17:14:00.057 回答