easyui的datagrid編輯(進(jìn)階版包含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;//刷新表格的時候?qū)⑿薷男刑栔每?    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 : '正在加載數(shù)據(jù)...',
                    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中進(jìn)行編輯
                                $("#datagrid").datagrid("acceptChanges");//在edit之前要接受上一次的修改內(nèi)容,否則如果這一次的修改出現(xiàn)了異常,會將前面所有的修改操作都撤銷(當(dāng)前這種撤銷是前端頁面顯示上的撤銷)。
                                $('#datagrid').datagrid('selectRow', index).datagrid('editCell', {index:index,field:field});
                                zbsjbj.editIndex = index;
                            }
                        }
                    }
                    ,onEndEdit:function(index,row,changes){//結(jié)束編輯,如果內(nèi)容有變化的話,那么ajax后臺修改
                        var change = false;
                        //console.log(row);
                        //console.log(changes);
                        for(x in changes){
                            change = true;
                            break;
                        }
                        if(change){
                            zbsjbj.saveChanges(row,changes);
                        }
                    }
                    //單元格編輯事件結(jié)束
                });
            }else{
                alert("查詢指標(biāo)字段出現(xiàn)異常!");
            }
        },
        error:function(request,state,e){
            alert("查詢指標(biāo)字段出現(xiàn)異常!");
        }
    });
}
,endEditing:function(field){//結(jié)束編輯
    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("正在保存修改內(nèi)容!");
    $.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("保存修改信息出現(xiàn)異常!");
            __closeMask();
        }
    });
}

combobox根據(jù)id獲取顯示內(nèi)容

function getTextById(arr,id){
    var text = "";
    try{
        $.each(arr,function(i,item){
            if(item.ID==id){
                text = item.TEXT;
                return false;
            }
            //因為datasys中數(shù)據(jù)有01這種,而01和1判斷不相等,所以轉(zhuǎn)換成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;
}

后臺返回數(shù)據(jù)

{"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":"起點(diǎn)樁號","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":"止點(diǎn)樁號","fieldName":"ROADENDS","fieldType":"07","id":71,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null},{"bmDef":null,"enumStr":"公路技術(shù)等級代碼","fieldDes":null,"fieldLen":null,"fieldMean":"技術(shù)等級","fieldName":"JSDJ","fieldType":"08","id":72,"isNull":null,"issys":null,"showIndex":null,"state":null,"tableName":null,"unit":null}],"公路技術(shù)等級代碼":[{"TEXT":"請選擇","ID":""},{"ID":"10","TEXT":"高速"},{"ID":"11","TEXT":"一級"},{"ID":"12","TEXT":"二級"},{"ID":"13","TEXT":"三級"},{"ID":"14","TEXT":"四級"},{"ID":"30","TEXT":"等外公路"}]},"status":1}}

進(jìn)一步要求(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找不到的錯誤,猜測是因為點(diǎn)擊之后立馬進(jìn)行關(guān)閉combobox導(dǎo)致的,所以這里改成延時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);
        }
    }
};

進(jìn)一步要求(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);
    }
});

進(jìn)一步要求(text開始編輯的時候獲取焦點(diǎn))

我的解決辦法是這樣的,我的editor的type是text,這樣就可以獲取到焦點(diǎn)。

$('#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();是獲取不到焦點(diǎn)的,需要這么處理(官網(wǎng)的demo就是這樣的):

var ed = $(this).datagrid('getEditor', param);
if (ed){
    if ($(ed.target).hasClass('textbox-f')){
        $(ed.target).textbox('textbox').focus();
    } else {
        $(ed.target).focus();
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,321評論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,559評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,442評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,835評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,581評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,922評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,931評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,096評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,639評論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,374評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,591評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,104評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,789評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,196評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,524評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,322評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,554評論 2 379

推薦閱讀更多精彩內(nèi)容

  • ¥開啟¥ 【iAPP實現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程,因...
    小菜c閱讀 6,494評論 0 17
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,826評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,740評論 25 708
  • 一個push系統(tǒng)的產(chǎn)品規(guī)劃,除了前期的需求調(diào)研,結(jié)合使用場景搭建push框架也是重中之重,在這里就來分享一下自己的...
    穆之清閱讀 3,657評論 0 2