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是gridurl: '/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 "<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', width: 180, sortable: true, hidden:true},{ title: '客户名称', field: 'CustomerName', width: 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', width: 180, sortable: true, hidden:true},{ title: '客户名称', field: 'Data1', width: 180, sortable: true },

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

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

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

  1. 基于MVC4+EasyUI的Web开发框架经验总结(8)--实现Office文档的预览

    在博客园很多文章里面,曾经有一些介绍Office文档预览查看操作的,有些通过转为PDF进行查看,有些通过把它转换为Flash进行查看,但是过程都是曲线救国,真正能够简洁方便的实现Office文档的预览 ...

  2. [转载]基于MVC4+EasyUI的Web开发框架经验总结(8)--实现Office文档的预览

    在博客园很多文章里面,曾经有一些介绍Office文档预览查看操作的,有些通过转为PDF进行查看,有些通过把它转换为Flash进行查看,但是过程都是曲线救国,真正能够简洁方便的实现Office文档的预览 ...

  3. 基于MVC4+EasyUI的Web开发框架经验总结(6)--在页面中应用下拉列表的处理

    在很多Web界面中,我们都可以看到很多下拉列表的元素,有些是固定的,有些是动态的:有些是字典内容,有些是其他表里面的名称字段:有时候引用的是外键ID,有时候引用的是名称文本内容:正确快速使用下拉列表的 ...

  4. (转)基于MVC4+EasyUI的Web开发框架经验总结(8)--实现Office文档的预览

    http://www.cnblogs.com/wuhuacong/p/3871991.html 基于MVC4+EasyUI的Web开发框架经验总结(8)--实现Office文档的预览 在博客园很多文章 ...

  5. 基于MVC4+EasyUI的Web开发框架经验总结(11)--使用Bundles处理简化页面代码

    基于MVC4+EasyUI的Web开发框架经验总结(11)--使用Bundles处理简化页面代码 在Web开发的时候,我们很多时候,需要引用很多CSS文件.JS文件,随着使用更多的插件或者独立样式文件 ...

  6. (转)基于MVC4+EasyUI的Web开发框架经验总结(12)--利用Jquery处理数据交互的几种方式...

    http://www.cnblogs.com/wuhuacong/p/4085682.html 在基于MVC4+EasyUI的Web开发框架里面,大量采用了Jquery的方法,对数据进行请求或者提交, ...

  7. (转)基于MVC4+EasyUI的Web开发框架经验总结(10)--在Web界面上实现数据的导入和导出...

    http://www.cnblogs.com/wuhuacong/p/3873498.html 数据的导入导出,在很多系统里面都比较常见,这个导入导出的操作,在Winform里面比较容易实现,我曾经在 ...

  8. (转)基于MVC4+EasyUI的Web开发框架经验总结(7)--实现省份、城市、行政区三者联动...

    http://www.cnblogs.com/wuhuacong/p/3841338.html 为了提高客户体验和进行一些技术探索,现在正准备把我自己的客户关系管理系统CRM在做一个Web的版本,因此 ...

  9. (转)基于MVC4+EasyUI的Web开发框架经验总结(1)-利用jQuery Tags Input 插件显示选择记录...

    http://www.cnblogs.com/wuhuacong/p/3667703.html 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开 ...

最新文章

  1. c语言根据日期算星期几入门,c语言详解  蔡勒(Zeller)公式计算某一天是星期几  极其方便...
  2. 涉及的一些操作的命令
  3. Zabbix中文乱码问题
  4. python列表逐行写入excel_python表格数据到excel-想问下python3怎么将列表数据逐行写入excel表格呢?...
  5. [android]-xml解析示便-SAX
  6. bzoj 4372 烁烁的游戏 —— 动态点分治+树状数组
  7. 【kafka】kafka UnknownProducerIdException raised broker locate producer metadata producerId
  8. 有人说如果车速每小时超过120公里,爆胎时无法挽回是真的吗?
  9. Label高度根据内容变化SnapKi
  10. linux监测服务日志脚本,LINUX下的一个性能监测脚本
  11. 复杂网络MATLAB工具箱
  12. Android日历控件
  13. SLG手游的战斗抽象
  14. linux磁盘分区、挂盘
  15. corosync+pacemaker高可用
  16. java duck的屏幕保护程序
  17. 平安科技联络云荣膺金融科技最佳云联络中心服务商
  18. 做什么网站赚钱?关于网站赚钱项目的剖析以及方向
  19. php fck,PHP中调用FCK的方法
  20. 卷积神经网络CNN(7)—— 限速交通标志分类

热门文章

  1. linux读取环境变量替换,linux Shell脚本学习笔记二(变量和环境变量)
  2. 在多字节的目标代码页中,没有此 Unicode 字符可以映射到的字符
  3. 基于javaweb mvc模式的图书馆管理系统(不含框架)
  4. HTML+CSS+JavaScript复习笔记持更(七)——CSS3常用属性之背景
  5. php按每小时显示数据,mysql-PHP按某月统计每个小时生成的数据
  6. 深入解析Windows窗口创建和消息分发
  7. 国外管理学博士国内计算机博士,教育部认可的国外管理学博士
  8. 如何将catia装配件附材料_在网上买的快餐桌椅如何安装?餐厅快餐桌椅安装顺序与流程知识...
  9. RTEMS实时操作系统精要(1)-简介
  10. go语言基础到提高(9)-go ide