有时候前台完成某个操作后要修改datagrid的值, 也许这个datagrid是没有保存的, 所以要修改后才能传递到后台; 也许要其他操作过后才需请求后台; 这些情况都需要前台对datagrid的单元格进行修改操作:
假设我们有一个” staffLogDetailGrid”的datagrid;
// 得到columns对象 var columns = $('#dg').datagrid("options").columns; // 得到rows对象 var rows = $('#dg').datagrid("getRows"); // 这段代码是// 对某个单元格赋值 rows[lastIndex][columns[0][5].field]=新的值; // 刷新该行, 只有刷新了才有效果 $('#dg').datagrid('refreshRow', lastIndex);
如果该行处于"行编辑"状态, 如果直接调用"refreshRow"方法. 会报data is undefined这个错; 需要先调用"endEdit", 再调用"refreshRow", 最后调用"selectRow"和"beginEdit"这两个方法便可了; 一定要先关闭行编辑才能刷新, 不然要报错的...这个问题搞了我很久额...代码如下:
$('#dg').datagrid('endEdit', lastIndex).datagrid('refreshRow', lastIndex).datagrid('selectRow', lastIndex).datagrid('beginEdit', lastIndex);
还有一种方法可以进行单元格的编辑: 如下
已知行坐标为lastindex;
var row = $('#dg').datagrid("selectRow", lastIndex).datagrid("getSelected"); row.gzsj = getNowDate(); console.info(row); $('#dg').datagrid('updateRow', row);