我希望以特定顺序在javascript变量中获取JQGrid的所有行。 我能够通过以下方式获取所有行的数据:
var rowData = $("#gridId").jqGrid("getRowData");
但我希望行的显示顺序与我在网格中输入的顺序相同。 我正在尝试创建一个表并通过网格获取其列详细信息。所以我要求列的顺序保持不变。有什么建议吗?
答案 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) ;