Jsf 如何按列而不是按行输出primefaces DataGrid组件的数据(转置数据)?

Jsf 如何按列而不是按行输出primefaces DataGrid组件的数据(转置数据)?,jsf,primefaces,datagrid,Jsf,Primefaces,Datagrid,Primefaces 5.0中有一个DataGrid组件。它显示按行分割的输入数据。 如何显示按列拆分的数据 A B C A D G D E F --> B E H G H C F 我在Primefaces的DataGrid组件中转置数据的解决方案是重写DataGridRenderer类的encodeTable()方法 @Override protected void encodeTable(FacesContext context, DataGrid

Primefaces 5.0中有一个DataGrid组件。它显示按行分割的输入数据。 如何显示按列拆分的数据

A B C       A D G
D E F  -->  B E H 
G H         C F 

我在Primefaces的DataGrid组件中转置数据的解决方案是重写
DataGridRenderer
类的
encodeTable()
方法

@Override
protected void encodeTable(FacesContext context, DataGrid grid) throws IOException {
    ResponseWriter writer = context.getResponseWriter();

    int columns = grid.getColumns();
    int firstRowIndex = grid.getFirst();
    int rowIndex = firstRowIndex;
    int rows = grid.getRows();
    int itemsToRender = rows != 0 ? rows : grid.getRowCount();
    int numberOfRowsToRender = (itemsToRender + columns - 1) / columns;

    String transpose = (String) grid.getAttributes().get("transpose");
    boolean isTranspose = transpose != null ? Boolean.valueOf(transpose) : false;

    writer.startElement("table", grid);
    writer.writeAttribute("class", DataGrid.TABLE_CLASS, null);
    writer.startElement("tbody", null);

    for (int i = 0; i < numberOfRowsToRender; i++) {

        writer.startElement("tr", null);
        writer.writeAttribute("class", DataGrid.TABLE_ROW_CLASS, null);

        for (int j = 0; j < columns; j++) {
            writer.startElement("td", null);
            writer.writeAttribute("class", DataGrid.TABLE_COLUMN_CLASS, null);

            if (isTranspose) {
                writer.writeAttribute("style", String.format("width: %d%%;", 100 / columns), null);
            }

            grid.setRowIndex(isTranspose ? numberOfRowsToRender * j + i + firstRowIndex : rowIndex);

            if (grid.isRowAvailable()) {
                renderChildren(context, grid);
            }
            rowIndex++;

            writer.endElement("td");
        }
        writer.endElement("tr");
    }

    grid.setRowIndex(-1);    //cleanup

    writer.endElement("tbody");
    writer.endElement("table");
}
现在我可以为
标记指定
transposable=“true”
属性。
代码还“修复”了样式表,使每个页面的列数相同,即使最后一页上没有足够的数据覆盖所有列

对这个问题有什么评论吗?或者最好提出一个答案。
<render-kit>
    <renderer>
        <component-family>org.primefaces.component</component-family>
        <renderer-type>org.primefaces.component.DataGridRenderer</renderer-type>
        <renderer-class>org.primefaces.component.datagrid.TransposableDataGridRenderer</renderer-class>
    </renderer>
</render-kit>