1

我已经在谷歌上搜索了 2 天,并尝试了我在网上看到的各种尝试,但似乎没有什么对我有用。

我正在尝试让richfaces 3 数据表对列进行排序,当我单击列标题时,实际上没有任何内容得到排序。

有人知道我缺少什么吗?我需要在我的支持 bean 上实现一个属性吗?

<rich:extendedDataTable id="resultsTable" value="#{tableBacking.results}" var="results" rowKeyVar="row">
        <rich:column>
            <f:facet name="header">
                <h:outputText value="Row Number" />
            </f:facet>                  
        </rich:column>

        <rich:columns value="#{tableBacking.columns == null ? '' : tableBacking.columns}" 
            var="columns" index="ind" id="column#{ind}" 
            sortBy="#{results[ind].data}" rendered="#{tableBacking.columns != null}">
            <f:facet name="header">
                <h:outputText value="#{columns.columnDescription}" />
            </f:facet>

            <h:outputText value="#{results[ind].data}" />

        </rich:columns>
    </rich:extendedDataTable>

TableLookupBacking bean

public class TableLookupBacking{
    private List<List<TableData>> results = null;
    private List<TableData> columns = new ArrayList<TableData>();

    public void search() {
        getData("");
    }

    private void getData(String whereClause) {

        try {
            DataDao dd = new DataDao();
            results = dd.getData(WebDataViewerConstants.SCHEMA_NAME, selectedTable, whereClause);
        } catch (Exception e) {
            FacesContext.getCurrentInstance().addMessage(null, new FacesMessage("Unable to retrieve data with selected search criteria in getData."));
        }
    }
// columns get set in another method that is triggered off something else the user does    

// Getters and Setters

}
4

1 回答 1

1

我终于弄明白了。我需要做的就是添加sortOrder="#{tableBacking.sortOrder[columns]}"到我的rich:columns标签中,然后在我的支持者中添加以下内容:

private Map<String, Object> sortOrder = new HashMap<String, Object>();

// setter and getter
于 2013-01-14T14:32:11.083 回答