easyui前台改变datagrid某单元格的值


有时候前台完成某个操作后要修改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);

  

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM