基于MVC+EasyUI的Web开发框架经验总结(9)–在Datagrid里面实现外键字段的转义操作
admin
2023-08-02 16:08:44
0

我们在使用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,
        width: 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\', width: 180, sortable: true},
              { title: \'编号\', field: \'HandNo\', width: 80, sortable: true },
              { title: \'姓名\', field: \'Name\', width: 80, sortable: true },
              { title: \'身份证号码\', field: \'IDCarNo\', width: 120, sortable: true },
              {
                  title: \'出生日期\', field: \'Birthday\', width: 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\', width: 180, sortable: true,
  formatter: function (value, row) {
      $.ajaxSettings.async = false;
      $.getJSON(\"/Customer/GetCustomerName?id=\" + value, function (result) {
          return \"\" + result + \"\";
      });
  }
},

但是,如果这样做,你会发现格式化函数没有办法调用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代表的是实体类,我们很难改变实体类里面的属性并赋值,那么我们也可以把它转换为DataTable了。

//增加一个客户名称字段,然后进行解析,构建一个DataTable返回
DataTable dtReturn = DataTableHelper.ListToDataTable(list);
dtReturn.Columns.Add(\"CustomerName\");

foreach (DataRow row in dtReturn.Rows)
{
    row[\"CustomerName\"] = BLLFactory.Instance.GetCustomerName(row[\"Customer_ID\"].ToString());
}
var result = new { total = dtReturn.Rows.Count, rows = dtReturn };

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

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

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

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

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

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

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

    /// 
    /// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
    /// 
    [DataMember]
    public string Data2 { get; set; }

    /// 
    /// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
    /// 
    [DataMember]
    public string Data3 { get; set; } 
    #endregion
}

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

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

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

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

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

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

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

相关内容

热门资讯

500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
python查找阿姆斯特朗数 题目解释 如果一个n位正整数等于其各位数字的n次方之和,则称该数为阿姆斯特朗数。 例如1^3 + 5...
Apache Doris 2.... 亲爱的社区小伙伴们,我们很高兴地向大家宣布,Apache Doris 2.0.0 版本已于...