• (转)基于MVC4+EasyUI的Web开发框架经验总结(9)--在Datagrid里面实现外键字段的转义操作


    http://www.cnblogs.com/wuhuacong/p/3872890.html

    我们在使用EasyUI的时候,很多情况下需要使用到表格控件datagrid,这个控件控件非常强大,使用起来很简洁,但是我在使用中,发现对于一个表里面的外键字段进行转义,并显示引用表的一些名称的操作,却显得比较难以实现,找了很多资料,基本上没有找到对应的解决方案。本文主要介绍我对这种外键字段转义的操作的实现方式,以便供大家参考了解。

    1、DataGrid的初始化操作

    在了解对内容的解析前,我们先来了解EasyUI里面Datagrid的初始化操作过程,然后逐步进行分析,寻求解决方式。

    一般情况下,Datagrid内容的初始化代码如下所示,注意下面红色部分的内容Customer_ID,就是我们需要转换为客户名称的处理。因为我们这里返回的表数据包含了一个外键ID:Customer_ID,我需要把它转换一下客户的名称。

    复制代码
            //实现对DataGird控件的绑定操作
            function InitGrid(queryData) {
                $('#grid').datagrid({   //定位到Table标签,Table标签的ID是grid
                    url: '/Contact/FindWithPager',   //指向后台的Action来获取当前用户的信息的Json格式的数据
                    title: '客户联系人', 
                    iconCls: 'icon-view',
                    height: 650,
                     function () { return document.body.clientWidth * 0.9 },//自动宽度
                    nowrap: true,
                    autoRowHeight: false,
                    striped: true,
                    collapsible: true,
                    pagination: true,
                    pageSize: 50,
                    pageList: [50, 100, 200],
                    rownumbers: true,
                    //sortName: 'Seq',    //根据某个字段给easyUI排序
                    sortOrder: 'asc',
                    remoteSort: false,
                    idField: 'ID',
                    queryParams: queryData,  //异步查询的参数
                    columns: [[
                        { field: 'ck', checkbox: true },   //选择
                          { title: '客户ID', field: 'Customer_ID',  180, sortable: true},
                          { title: '编号', field: 'HandNo',  80, sortable: true },
                          { title: '姓名', field: 'Name',  80, sortable: true },
                          { title: '身份证号码', field: 'IDCarNo',  120, sortable: true },
                          {
                              title: '出生日期', field: 'Birthday',  120, sortable: true,
                              formatter: function (value, rec, index) {
                                  if (value == undefined) {
                                      return "";
                                  }
                                  if ((value + '').indexOf('1900') == 0) {
                                      return "";
                                  }
                                  return value;
                              }
                          }
                      ]],
                    toolbar: [{
                        id: 'btnAdd',
                        text: '添加',
                        iconCls: 'icon-add',
                        handler: function () {                        
                            ShowAddDialog();//实现添加记录的页面
                        }
                    }, '-', {
                        id: 'btnEdit',
                        text: '修改',
                        iconCls: 'icon-edit',
                        handler: function () {                        
                            ShowEditOrViewDialog();//实现修改记录的方法
                        }
                    }, '-', {
                        id: 'btnDelete',
                        text: '删除',
                        iconCls: 'icon-remove',
                        handler: function () {                        
                            Delete();//实现直接删除数据的方法
                        }
                    }, '-', {
                        id: 'btnView',
                        text: '查看',
                        iconCls: 'icon-table',
                        handler: function () {                        
                            ShowEditOrViewDialog("view");//实现查看记录详细信息的方法
                        }
                    }, '-', {
                        id: 'btnReload',
                        text: '刷新',
                        iconCls: 'icon-reload',
                        handler: function () {
                            //实现刷新栏目中的数据
                            $("#grid").datagrid("reload");
                        }
                    }],
                    onDblClickRow: function (rowIndex, rowData) {
                        $('#grid').datagrid('uncheckAll');
                        $('#grid').datagrid('checkRow', rowIndex);
                        ShowEditOrViewDialog();
                    }
                })
            };
    复制代码

    2、尝试失败的操作

    1)使用格式化函数Formatter

    针对以上的处理,有些人可能很快就想到使用格式化Formatter来实现了,一般情况下处理转义和自定义显示操作,非此莫属。

    有可能想使用的代码如下所示。

    复制代码
                          {
                              title: '客户名称', field: 'Customer_ID',  180, sortable: true,
                              formatter: function (value, row) {
                                  $.ajaxSettings.async = false;
                                  $.getJSON("/Customer/GetCustomerName?id=" + value, function (result) {
                                      return "<span>" + result + "</span>";
                                  });
                              }
                          },
    复制代码

    但是,如果这样做,你会发现格式化函数没有办法调用ajax的操作,获取对应的数据,也就是无法进行解析客户的ID为名称。因此这种方法,失败!

    2)使用onLoadSuccess函数

    这个onLoadSuccess函数,本意就是在Datagrid顺利加载后执行的函数,一般情况下,我想在加载后,在更新表格里面的数据,如下面的代码所示。

    复制代码
                    onLoadSuccess: function (data) {
                        var rows = $("#grid").datagrid("getRows");
                        if (rows.length >= 1) {
                            for (var i = 0; i < rows.length; i++) {
                                $.getJSON("/Customer/GetCustomerName?id=" + rows[i].Customer_ID, function (result) {
                                    $('#grid').datagrid('updateRow', { index: 0, row: { field: result } });
                                });
                            }
                        }
                    }
    复制代码

    下面的方法也是通过Ajax的方式获取数据,然后进行更新,不过很不幸,也不通过,无法正常解析。

    3、成功解析的方式

    好了,既然无法通过上面脚本的方式来进行解析,我们通过曲线救国的方式,应该也是可以的。

    由于Datagrid显示的数据是下面的方式就可以的

                var result = new { total = list.Count, rows = list };

    那么我们在返回数据给datagrid的控制器函数里面,对返回的内容,增加一个“客户名称”的信息,应该就可以了。

    1)转换内容为DataTable并增加字段

    但是我的框架里面,返回的内容都设置为了List<T>的这种方式,也就是T代表的是实体类,我们很难改变实体类里面的属性并赋值,那么我们也可以把它转换为DataTable了。

    复制代码
                //增加一个客户名称字段,然后进行解析,构建一个DataTable返回
                DataTable dtReturn = DataTableHelper.ListToDataTable<ContactInfo>(list);
                dtReturn.Columns.Add("CustomerName");
    
                foreach (DataRow row in dtReturn.Rows)
                {
                    row["CustomerName"] = BLLFactory<Customer>.Instance.GetCustomerName(row["Customer_ID"].ToString());
                }
                var result = new { total = dtReturn.Rows.Count, rows = dtReturn };
    复制代码

    通过函数DataTableHelper.ListToDataTable<ContactInfo>(list);可以把列表的内容构建成一个DataTable的内容,并增加一个CustomerName的字段,然后遍历每一行,填入解析Customer_ID后的名称,并返回记录就可以了。

    在视图里面,我们通过增加一个字段进行绑定就可以了,如下所示。

                          {
                              title: '客户ID', field: 'Customer_ID',  180, sortable: true, hidden:true
                          },
                          { title: '客户名称', field: 'CustomerName',  180, sortable: true },

    2)在实体类基类增加一些额外的字段属性

    刚才我们看到,把实体类列表转换为DataTable,然后并遍历赋值,挺麻烦的一件事,也可能影响一些性能,如果我们实体类里面有一些备用的属性作为内容解析,在界面上直接使用这些备用属性就可以了,这样会更加方便。

    因此我在所有实体类的基类里面增加三个属性,Data1、Data2、Data3,有点类似Visio模具形状的属性设置了,呵呵。

    复制代码
        /// <summary>
        /// 框架实体类的基类
        /// </summary>
        [DataContract]
        public class BaseEntity
        {
            #region 在实体类存储一些特殊的数据
            /// <summary>
            /// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
            /// </summary>
            [DataMember]
            public string Data1 { get; set; }
    
            /// <summary>
            /// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
            /// </summary>
            [DataMember]
            public string Data2 { get; set; }
    
            /// <summary>
            /// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
            /// </summary>
            [DataMember]
            public string Data3 { get; set; } 
            #endregion
        }
    复制代码

    有了这些备用的属性,我们就可以解决外键转义的内容存储问题了。

    在查询里面,我们只需要遍历一次,把转换好的内容赋值给对应的实体类属性就好了。

                foreach (ContactInfo info in list)
                {
                    //增加一个特殊字段的转义
                    info.Data1 = BLLFactory<Customer>.Instance.GetCustomerName(info.Customer_ID);
                }

    最后在视图里面,我们的代码如下所示。

                          {
                              title: '客户ID', field: 'Customer_ID',  180, sortable: true, hidden:true
                          },
                          { title: '客户名称', field: 'Data1',  180, sortable: true },

    主界面里面的列表展示如下所示。

    数据导入界面里面的列表展示如下所示。

  • 相关阅读:
    Flask 学习7. make_response() 自定义响应内容 上海
    Flask 学习5.请求对象Request 上海
    Flask 学习3.设置 HTTP 请求 方法(get/post) 上海
    Flask 学习2.url访问地址(路由配置) 上海
    Flask 学习9. 开启调试模式(debug模式)的2种方法 上海
    modelmapper 简单智能的对象映射工具
    使用jsch 实现ssh tunnel
    jimfs java 内存文件系统实现
    基于commonsdiscovery 开发简单的插件化java系统
    dremio 20 版本可以下载体验了
  • 原文地址:https://www.cnblogs.com/telwanggs/p/7125881.html
Copyright © 2020-2023  润新知