snaif_lx
snaif_lx
2015-09-05 08:17
采纳率: 80%
浏览 2.1k
已采纳

easyui dategrid 显示的值和编辑的值类型不同怎么办?

//---民族
         {
             field: 'NMK07', title: '民族', width: 100, sortable: true,
             editor: {type: 'combobox', options: {
                 required: true,
                 //formatter: unitformatter,
                 url: '/handler/dict.ashx?flag=tree&t=Nation', parentField: 'pid',
                 textFiled: 'text',
                 valueField: 'id',
                 method: 'get',
                 lines: true,
                 editable: false,
                 panelHeight: 130,
                 panelMaxWidth: 200
             }
             }
         },
         //----------------

                    url获取到的是json格式,内容如下:
                    [{"id":0,"pid":-1,"text":"请选择"},{"id":3,"pid":-1,"text":"123"},{"id":2,"pid":-1,"text":"民族1"}]

情况说明:

数据库中NMK07字段为int字段,用于存储对应民族表的ID,这样就导致在dategrid的时候显示NMK07直接显示的是ID值,而不是对应民族的名称
如果后台生成json时就获取成名族名称的话,在编辑列数据时,combobox里又无法获取得到民族的ID
请问,这样的情况如何处理?
datagrid默认显示时需要民族的名称,编辑时又需要的是民族的ID,同一个列的情况下,该怎么办呢?
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • showbo
    已采纳

    你用一个script标签加载/handler/dict.ashx?flag=tree&t=Nation这个页面在页面上生成名族的json数组对象,然后你的editor不需要指定url了,直接使用data配置指向这个数据即可,可以大大提高效率,不需要每次用ajax加载

    如你ashx原来输出[{}...]这个格式的数据,变成var arrMZ=[{}....]这种,然后用script加载你的这个动态页

     <script src="/handler/dict.ashx?flag=tree&t=Nation"></script>
    

    ,这样arrMZ就是存储你名族的json对象数组了

      editor: {type: 'combobox', options: {
                     required: true,
                     //formatter: unitformatter,
                     //url: '/handler/dict.ashx?flag=tree&t=Nation', parentField: 'pid',
                                    data:arrMZ//////这样配置本地数据就可以了
    

    然后给datagrid配置formatter,遍历arrMZ对比传入的value返回对应的显示值

       {
                 field: 'NMK07', title: '民族', width: 100, sortable: true,
                            formatter:function(v){
                            for(var i=0;i<arrMZ.length;i++){
                               if(arrMZ[i]['id']==v)return arrMZ[i]['text']
                            }
                            }
    
    点赞 评论
  • snaif_lx
    snaif_lx 2015-09-05 08:30

    网上有方法formatter
    function unitFormatter(value, rowData, rowIndex) {

    if (value == 0) {

    return "";

    }

    for (var i = 0; i < unitJSON.length; i++) {

    if (unitJSON[i].value == value) {

    return unitJSON[i].name;

    }

    }

    return value;

    }

    但是实际情况中json是从数据库提取出来的url: '/handler/dict.ashx?flag=tree&t=Nation',
    不知道这个unitFormatter怎么做

    点赞 评论
  • devmiao
    devmiao 2015-09-05 14:13
    点赞 评论
  • jetlee1028
    jetlee1028 2015-09-06 01:02

    使用formatter,佛matter能传入这行数据的实体,你在查询实体的时候,设置一个字段作为显示内容的字段,formatter的时候,return对应的文字即可

    点赞 评论
  • snaif_lx
    snaif_lx 2015-09-06 10:55

    图片说明

    点赞 评论

相关推荐