easyui的datagrid编辑(进阶版包含combobox和textbox)

combobox效果图
textbox效果图

引入公共文件datagridEdit.js

这个公共文件中定义了editCell方法

var gridEdit={
    init:function(){
        $.extend($.fn.datagrid.methods, {
            editCell: function(jq,param){
                return jq.each(function(){
                    var opts = $(this).datagrid('options');
                    var fields = $(this).datagrid('getColumnFields',true).concat($(this).datagrid('getColumnFields'));
                    for(var i=0; i<fields.length; i++){
                        var col = $(this).datagrid('getColumnOption', fields[i]);
                        col.editor1 = col.editor;
                        if (fields[i] != param.field){
                            col.editor = null;
                        }
                    }
                    $(this).datagrid('beginEdit', param.index);
                    for(var i=0; i<fields.length; i++){
                        var col = $(this).datagrid('getColumnOption', fields[i]);
                        col.editor = col.editor1;
                    }
                });
            }
        });
    }
}
$(function(){
    gridEdit.init();
});

生成datagrid

datagrid:function(){
    zbsjbj.editRow = undefined;//刷新表格的时候将修改行号置空
    var dyColumns = [];//从库里查出来表格的各列
    $.ajax({
        url:"queryRoadTargetsByTableName.action",
        type:"post",
        data:{
            "roadTargets.tableName":zbManage.zbMap.tableName
        },
        success:function(data){
            if(data.res.status==1){
                //console.log(data);
                $.each(data.res.obj.list, function(i, item){//遍历表格的各列
                    var oneC = {};
                    if(item.fieldName=='ROADSTART'){
                        oneC['field']="ROADSTARTTEXT";
                    }else if(item.fieldName=='ROADENDS'){
                        oneC['field']="ROADENDSTEXT";
                    }else{
                        oneC['field']=item.fieldName;
                    }
                    oneC['field']==""?"ROADSTARTTEXT":item.fieldName;
                    oneC['title']=item.fieldMean;
                    oneC['width']=100;
                    oneC['align']='center';
                    if(item.fieldName!='ROADCODE' && item.fieldName!='ROADNAME' && item.fieldName!='ROADSTART'&&item.fieldName!='ROADENDS'){
                        if(item.fieldType=='08'||item.fieldType==8){
                            oneC['editor']={//定义combobox的editor
                                    type:'combobox',
                                    options:{
                                        valueField:'ID',
                                        textField:'TEXT',
                                        data: data.res.obj[item.enumStr],//这个data是从库里查出来的
                                    }
                                };
                            //添加format方法
                            oneC['formatter']= function(value,row,index){
                                return getTextById(data.res.obj[item.enumStr],value);
                            };
                        }else{
                            //textbox方法
                            oneC['editor']='textbox';
                        }
                    }
                    dyColumns.push(oneC);
                });
                $('#datagrid').datagrid({
                    url : "zbsjbjQueryForPage.action",
                    queryParams : {
                        "id":zbManage.zbMap.id,
                        "roadCode":lxTree.roadCode
                    },
                    loadMsg : '正在加载数据...',
                    pageNumber:1,
                    singleSelect: true,
                    fit : true,
                    fitColumns:true,
                    border : true,
                    rownumbers : true,
                    pagination : true,
                    striped : true,
                    onLoadSuccess:function(data){
                        $("#datagrid").datagrid("resize");
                    },
                    columns : new Array(dyColumns)
                    ,onClickRow:function(index,field,value){//单击,停止编辑
                        zbsjbj.endEditing(field);
                    }
                    //单元格编辑事件开始
                    ,onDblClickCell:function(index,field,value){//双击,开始编辑
                        if (zbsjbj.endEditing(field)){
                            if(field=='ROADCODE' || field=='ROADSTARTTEXT' || field=='ROADENDSTEXT' || field=='ROADPOSTEXT'){//如果是这种类型,显示一个弹窗
                                zbsjbj.rowIndex = index;
                                zbsjbj.showUpWin();
                            }else{//在datagrid中进行编辑
                                $("#datagrid").datagrid("acceptChanges");//在edit之前要接受上一次的修改内容,否则如果这一次的修改出现了异常,会将前面所有的修改操作都撤销(当前这种撤销是前端页面显示上的撤销)。
                                $('#datagrid').datagrid('selectRow', index).datagrid('editCell', {index:index,field:field});
                                zbsjbj.editIndex = index;
                            }
                        }
                    }
                    ,onEndEdit:function(index,row,changes){//结束编辑,如果内容有变化的话,那么ajax后台修改
                        var change = false;
                        //console.log(row);
                        //console.log(changes);
                        for(x in changes){
                            change = true;
                            break;
                        }
                        if(change){
                            zbsjbj.saveChanges(row,changes);
                        }
                    }
                    //单元格编辑事件结束
                });
            }else{
                alert("查询指标字段出现异常!");
            }
        },
        error:function(request,state,e){
            alert("查询指标字段出现异常!");
        }
    });
}
,endEditing:function(field){//结束编辑
    if (zbsjbj.editIndex == undefined){return true}
    if ($('#datagrid').datagrid('validateRow', zbsjbj.editIndex)){
        $('#datagrid').datagrid('endEdit', zbsjbj.editIndex);
        zbsjbj.editIndex = undefined;
        return true;
    } else {
        return false;
    }
}
,saveChanges:function(row,changes){//保存变化
    //console.log(row);
    //console.log(changes);
    var f;
    var v;
    for(var x in changes){
        f = x;
        v = changes[x];
        break;
    }
    __showMask("正在保存修改内容!");
    $.ajax({
        url:"zbsjbcUpData.action",
        traditional: true,
        data:{
            "id":row.ID,
            "t":zbManage.zbMap.tableName,
            "f":f,
            "v":v,
            "tableType":zbManage.zbMap.tableType,
            "lineType":zbManage.zbMap.lineType
        },
        type:"post",
        success:function(data){
            if(data.res.status==1){
            }else{
                $("#datagrid").datagrid("rejectChanges");
                alert(data.res.msg);
            }
            __closeMask();
        },
        error:function(request,status,e){
            alert("保存修改信息出现异常!");
            __closeMask();
        }
    });
}

combobox根据id获取显示内容

function getTextById(arr,id){
    var text = "";
    try{
        $.each(arr,function(i,item){
            if(item.ID==id){
                text = item.TEXT;
                return false;
            }
            //因为datasys中数据有01这种,而01和1判断不相等,所以转换成int比较
            try{
                if(parseInt(item.ID)==parseInt(id)){
                    text = item.TEXT;
                    return false;
                }
            }catch(e){
                
            }
            
        });
    }catch(Exception){
        
    }
    return text;
}

后台查询的combox的data

var isNullMap = [
{'ID':0,'TEXT':'否'},
{'ID':1,'TEXT':'是'},
]

后台查询表格的各列

public Map queryRoadTargetsByTableName(RoadTargets rts) throws Exception{
    Map resMap = new HashMap();
    //查询各列
    String sql = "select id,fieldname,fieldmean,FIELDTYPE,enum from roadtargets where tablename=? order by showindex asc";
    List<RoadTargets> rtL = jdbcTemplate.query(sql, new Object[]{rts.getTableName()}, new RowMapper(){
        public Object mapRow(ResultSet rs, int i) throws SQLException {
            RoadTargets rts = new RoadTargets();
            rts.setId(rs.getLong("id"));
            rts.setFieldName(rs.getString("fieldname"));
            rts.setFieldMean(rs.getString("fieldmean"));
            rts.setFieldType(rs.getString("FIELDTYPE"));
            rts.setEnumStr(rs.getString("enum"));
            return rts;
        }
    });
    resMap.put("list", rtL);
    List enumList;
    Map nullMap = new HashMap(){{put("ID","");put("TEXT","请选择");}};
    for(RoadTargets rtTemp : rtL){
        //如果这一列是combobox类型的话,那么从库中查询所有的option项,然后扔到一个map中
        if((rtTemp.getFieldType().equals("08") || rtTemp.getFieldType().equals("8")) && rtTemp.getEnumStr().length()>0){
            sql = "select code ID,codemean TEXT from enuminfo where enumname=? order by showindex asc";
            enumList = jdbcTemplate.queryForList(sql, rtTemp.getEnumStr());
            enumList.add(0, nullMap);
            resMap.put(rtTemp.getEnumStr(), enumList);
        }
    }
    return resMap;
}

后台返回数据

{"res":{"msg":"操作成功","obj":{"list":[{"bmDef":null,"enumStr":null,"fieldDes":null,"fieldLen":null,"fieldMean":"路线编码","fieldName":"ROADCODE","fieldType":"02","id":68,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null},{"bmDef":null,"enumStr":null,"fieldDes":null,"fieldLen":null,"fieldMean":"路线名称","fieldName":"ROADNAME","fieldType":"02","id":69,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null},{"bmDef":null,"enumStr":null,"fieldDes":null,"fieldLen":null,"fieldMean":"起点桩号","fieldName":"ROADSTART","fieldType":"07","id":70,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null},{"bmDef":null,"enumStr":null,"fieldDes":null,"fieldLen":null,"fieldMean":"止点桩号","fieldName":"ROADENDS","fieldType":"07","id":71,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null},{"bmDef":null,"enumStr":"公路技术等级代码","fieldDes":null,"fieldLen":null,"fieldMean":"技术等级","fieldName":"JSDJ","fieldType":"08","id":72,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null}],"公路技术等级代码":[{"TEXT":"请选择","ID":""},{"ID":"10","TEXT":"高速"},{"ID":"11","TEXT":"一级"},{"ID":"12","TEXT":"二级"},{"ID":"13","TEXT":"三级"},{"ID":"14","TEXT":"四级"},{"ID":"30","TEXT":"等外公路"}]},"status":1}}

进一步要求(combobox选中一项之后立马自动提交)

我对上面的editor做了下面的修改:

oneC['editor']={
    type:'combobox',
    options:{
        editable:false,
        valueField:'ID',
        textField:'TEXT',
        data: data.res.obj[item.enumStr],
        onSelect:function(record){
            //console.log(record);
            zbsjbj.endEditing();
        }
    }
};

上面的修改能够自动完成提交,但是控制台一直报一个panel找不到的错误,猜测是因为点击之后立马进行关闭combobox导致的,所以这里改成延时500ms。
修改上面的onSelect:

oneC['editor']={
    type:'combobox',
    options:{
        editable:false,
        valueField:'ID',
        textField:'TEXT',
        data: data.res.obj[item.enumStr],
        onSelect:function(record){
            //console.log(record);
            window.setTimeout(zbsjbj.endEditing,500);
        }
    }
};

进一步要求(text回车提交)

解决思路,每次开始编辑之后,在editor对象上绑定keyup事件。

$('#datagrid').datagrid('selectRow', index).datagrid('editCell', {index:index,field:field});
var ed = $('#datagrid').datagrid('getEditor', {index:index,field:field});
$(ed.target).bind('keyup', function() {
    if (window.event.keyCode == 13) {
        window.setTimeout(zbsjbj.endEditing,500);
    }
});

进一步要求(text开始编辑的时候获取焦点)

我的解决办法是这样的,我的editor的type是text,这样就可以获取到焦点。

$('#datagrid').datagrid('selectRow', index).datagrid('editCell', {index:index,field:field});
var ed = $('#datagrid').datagrid('getEditor', {index:index,field:field});
$(ed.target).focus();

如果,editor的type是textbox,那么直接$(ed.target).focus();是获取不到焦点的,需要这么处理(官网的demo就是这样的):

var ed = $(this).datagrid('getEditor', param);
if (ed){
    if ($(ed.target).hasClass('textbox-f')){
        $(ed.target).textbox('textbox').focus();
    } else {
        $(ed.target).focus();
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容

  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,344评论 0 17
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,579评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,370评论 25 707
  • 一个push系统的产品规划,除了前期的需求调研,结合使用场景搭建push框架也是重中之重,在这里就来分享一下自己的...
    穆之清阅读 3,635评论 0 2