JQGrid getRowData按特定顺序排列所有行

时间:2013-09-03 06:12:52

标签: javascript jquery jqgrid

我希望以特定顺序在javascript变量中获取JQGrid的所有行。 我能够通过以下方式获取所有行的数据:

var rowData = $("#gridId").jqGrid("getRowData");

但我希望行的显示顺序与我在网格中输入的顺序相同。 我正在尝试创建一个表并通过网格获取其列详细信息。所以我要求列的顺序保持不变。有什么建议吗?

1 个答案:

答案 0 :(得分:0)

您可以显式地将jqgrid rowdata推送到数组,然后将其转换为json字符串。

要做到这一点,您可以使用类似下面给出的函数迭代jqgrid行:(来自Oleg's answer

var gridData= {}; 
var $grid = jQuery("#gridId"), rows = $grid[0].rows, cRows = rows.length,
    iRow, rowId, row, cellsOfRow;


for (iRow = 0; iRow < cRows; iRow++) {
    row = rows[iRow];
    if ($(row).hasClass("jqgrow")) {
        cellsOfRow = row.cells;
        // row represent the row with cellsOfRow.length cells.
        // So one can use for loop with iCol between 0 and cellsOfRow.length
        // cellsOfRow[iCol] represent the cell with the index iCol
        // and $(cellsOfRow[iCol]).text() - the text of the cell
    }
}

在循环内部,您可以将celldata推送到数组。

gridData['column_index1'] = $(cellsOfRow[0]).text();
gridData['column_index2'] = $(cellsOfRow[1]).text();

.............................................

最后使用

将gridData转换为json字符串
var result = JSON.stringify(gridData) ;