首先是自定义了一个方法uodateColumn更新列值  

     /**
*自定义的修改列值方法
*/
$.extend($.fn.datagrid.methods, {
updateColumn: function(datagrid,data) {
datagrid.each(function(){
//获取缓存中的配置数据
var gridObj=$.data(this,"datagrid");
var opts=gridObj.options;
//获取行数据
var row=opts.finder.getRow(this,data.index);
data.row=data.row||{};
var update=false;
//判断是否需要更新
for(var updateColumn in data.row){
if(data.row[updateColumn]!==row[updateColumn]){
update=true;
break;
}
}
if(update){
var tr=opts.finder.getTr(this,data.index);
var view=opts.view.renderRow.call(opts.view,this,["attr1"],true,data.index,data.row);
if(tr.hasClass("datagrid-row-editing")){
//找到所有需要更新值的列
tr.find('div').each(function(i){
if(data.row[$(this).parent().attr('field')]!=undefined){
if($(this).attr('class').indexOf('datagrid-editable')!=-1){
var ed=$.data(this,"datagrid.editor");
if(ed!=undefined){
ed.actions.setValue(ed.target,data.row[$(this).parent().attr('field')]);
}else{
$(this).html(data.row[$(this).attr('field')]);
}
}else{
$(this).html(data.row[$(this).attr('field')]);
$(this).addClass("datagrid-editable");
}
}
});
}
}
});
}
});

在这里,还有一个需要注意的时,我们将没在编辑状态下的列设值的同时添加了class:datagrid-editable;

所以在easyui.min.js中针对结束编辑的方法中会对该类进行扫描获取editor对象,但我们在这里是获取不到的。

所以在源码中我们加入了以下处理方法:

if(ed!=undefined){
var t=$(ed.target);
var _6eb=t.data("textbox")?t.textbox("textbox"):t;
_6eb.triggerHandler("blur");
var _6ec=ed.actions.getValue(ed.target);
if(row[_6ea]!=_6ec){
row[_6ea]=_6ec;
_6e8=true;
_6e9[_6ea]=_6ec;
}
}else{
$(this).removeClass("datagrid-editable");
var _6cv=$(this).html();
if(row[_6ea]!=_6cv){
row[_6ea]=_6cv;
_6e8=true;
_6e9[_6ea]=_6cv;
}
}

其实更明确的做法是将endEdit也重写了。这样就避免了懂源码。

在html页面中按照easyui的表格使用,声明表格:

<pre name="code" class="html">$('#demo').datagrid({
fitColumns: true,
iconCls: 'icon-edit',
singleSelect: true,
url: 'js/datagrid_data1.json',
method: 'get',
onClickRow: onClickRow,
onEndEdit: onEndEdit,
columns: [
[{
field: 'itemid',
title: 'Item ID',
width: 20,
align: 'center',
checkbox: true
}, {
field: 'productid',
title: 'productid',
width: 20,
sortable: true,
align: 'center'
}, {
field: 'listprice',
title: 'List Price',
width: 20,
align: 'center',
editor: {
type: 'numberbox',
options: {
precision: 2,
groupSeparator: ','
}
}
}, {
field: 'unitcost',
title: 'unitcost',
width: 20,
sortable: true,
editor: {
type: 'textbox'
}
}, {
field: 'attr1',
title: 'attr1',
width: 20,
sortable: true,
editor:{
type:'datebox'
}
}, {
field: 'status',
title: 'status',
width: 20,
sortable: true,
align: 'left',
editor:{
type:'combobox',
options:{
valueField:'id',
textField:'text',
data:[{id:1,text:'一号'},{id:2,text:'二号'}]
}
}
}]
]
});

//声明一些打开编辑的事件

var editIndex = undefined;

            function endEditing() {
if (editIndex == undefined) {
return true
}
if ($('#demo').datagrid('validateRow', editIndex)) {
$('#demo').datagrid('endEdit', editIndex);
editIndex = undefined;
return true;
} else {
return false;
}
} function onClickRow(index) {
if (editIndex != index) {
if (endEditing()) {
$('#demo').datagrid('selectRow', index).datagrid('beginEdit', index);
var ed = $('#demo').datagrid('getEditor', {
index: index,
field: 'listprice'
});
if (ed) {
ed.target.textbox({
inputEvents: $.extend({}, $.fn.textbox.defaults.inputEvents, {
keydown: function(e) {
if (e.keyCode == 13) {
var row = $('#demo').datagrid('getSelected');
$('#demo').datagrid('updateColumn',{index:index,row:{attr1:'2016-01-12',status:'1',unitcost:'33'}});
}
}
})
});
}
editIndex = index;
} else {
setTimeout(function() {
$('demo').datagrid('selectRow', editIndex);
}, 0);
}
}
}
function onEndEdit(index, row) {
console.log(row);
}

easyui 在编辑状态下,动态修改其他列值。的更多相关文章

  1. cxgrid 非编辑状态下复制当前列的值 真折腾人

    1.自带的CTRL +C 只能复制整行,不知是不是版本问题. 2.有分组这个代码就不行了 s:= G1DBView.DataController.Values[G1DBView.Controller. ...

  2. ListView在编辑状态下不能获取修改后的值,无法更新数据

    ListView在编辑状态下不能获取修改后的值,获取到的总是以前的值解决方法:在page_load事件里写: if(!IsPostBack) { ListViewBind(); } 原因:这涉及到as ...

  3. datagrid combobox事件更新编辑状态下的datagrid行

    请问如何从上图状态 点击下拉的combobox中值然后在不取消datagrid编辑状态下更新这一行另一列的数据,达到下图这样的效果: 非常感谢! 给你的combobox  绑定一个onSelect 事 ...

  4. iOS开发UI篇-tableView在编辑状态下的批量操作(多选)

    先看下效果图 直接上代码 #import "MyController.h" @interface MyController () { UIButton *button; } @pr ...

  5. ubuntu中vi在编辑状态下方向键不能用的解决

    ubuntu中vi在编辑状态下方向键不能用,还有回格键不能删除等,我们平时习惯的一些键都不能使用. 解决办法: 可以安装vim full版本,在full版本下键盘正常,安装好后同样使用vi命令. 安装 ...

  6. OSG立体模式下动态修改相机远近裁剪面的实现

    1. 非立体模式下动态修改相机远近裁剪面 class GLB_DLLCLASS_EXPORT CGlbGlobeClipHandler : public osg::NodeCallback    { ...

  7. 解决:WdatePicker新增状态下只能取比当前月份大的月份,编辑状态下只能取比当前input里指定月份的月份大的值

    onclick="WdatePicker({ dateFmt: 'yyyy-MM', autoPickDate: true, minDate: this.value==''?'%y-#{%M ...

  8. odoo14 编辑状态和非编辑状态下隐藏

    1 <div class="oe_edit_only"> 2 <a name="remove_group_id" type="obj ...

  9. 修改UIView的默认Layer后,修改View的值会动态修改Layer的值

    修改UIView的默认Layer后,修改View的值会动态修改Layer的值 效果图: 如上图所示,当我们修改了一个UIView的子类中的Layer内置类型时(如上图中我们将CALayer直接替换成了 ...

随机推荐

  1. ROS_Kinetic_20 ROS基础补充

    ROS_Kinetic_20 ROS基础补充 1 手动创建ROS功能包 参考官网:http://wiki.ros.org/cn/ROS/Tutorials/Creating%20a%20Package ...

  2. 新手学python(1):解析XML与系统调用

    最近需要做一个项目,完成一批音乐的格式转换.由于之前并未学习过python,所以想借此机会学一下.在介绍自己的学习过程之前,先把项目简要描述一下.目前在一台服务器a上有几十万首原始的MP3音乐文件,现 ...

  3. (NO.00004)iOS实现打砖块游戏(四):砖块类的实现

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 用Xcode打开之前SpriteBuilder创建的项目,我们现 ...

  4. Gradle 笔记——Java构建入门

    Gradle是一个通用的构建工具,通过它的构建脚本你可以构建任何你想要实现的东西,不过前提是你需要先写好构建脚本的代码.而大部分的项目,它们的构建流程基本是一样的,我们不必为每一个工程都编写它的构建代 ...

  5. flexbox基本原理

    新版的flexbox规范分两部分:一部分是container,一部分是 items. flexbox是一整套布局规范,包含了多个css属性,所以学习起来比`float: left;` 这样简单的布局要 ...

  6. Oracle生成查询包含指定字段名对应的所有数据表记录语句

    应用场合:已知字段名字,查询数据库中所有数据表中包含该字段名的所有数据表 操作办法:指定字段名,数据库表用户,执行下面查询语句即可 --Oracle生成查询包含指定字段名对应的所有数据表记录语句 de ...

  7. GDAL中MEM格式的简单使用示例

    GDAL库中提供了一种内存文件格式--MEM.如何使用MEM文件格式,主要有两种,一种是通过别的文件使用CreateCopy方法来创建一个MEM:另外一种是图像数据都已经存储在内存中了,然后使用内存数 ...

  8. Asp.Net中使用JQueryEasyUI--善良公社项目

    jQuery UI 是以 jQuery 为基础的开源 JavaScript 网页用户界面代码库.包含底层用户交互.动画.特效和可更换主题的可视控件.我们可以直接用它来构建具有很好交互性的web应用程序 ...

  9. Java-Iterator总结

    纸上得来终觉浅,绝知此事要躬行  --陆游    问渠那得清如许,为有源头活水来  --朱熹 迭 代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构. ...

  10. OpenCV 轮廓检测

    使用OpenCV可以对图像的轮廓进行检测.这是之前用过的代码,挺简单的,回顾一下.主要要进行以下2步操作: 1.cvThreshold():对图像进行二值化处理 2.cvFindContours(): ...