所以,我已经尝试了 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;
}
所以,对象可以到达方法,但是,我需要知道如何传递参数或其他东西,这样我才能知道我指的是哪一列。感谢你们。