ExtJS+WCF+LINQ打造全功能Grid

news/2024/7/21 7:40:42 标签: extjs, wcf, linq, json, excel, ajax
作者: jillzhang
出处: http://jillzhang.cnblogs.com/ 

本系列文章列表

1)  Ajax访问Xml Web Service的安全问题以及解决方案

2)  Ajax与WCF交互-WCF之美

3)  Ajax与Wcf交互-JSON

4)  ExtJs与WCF交互:生成树

5)  用ExtJs+Linq+Wcf打造简单grid

6)  ExtJs+WCF+LINQ实现分页Grid

7)  ExtJs与WCF之间的跨域访问

8)  异步调用Restful的WCF服务

9)  用Restful方式调用WCF进行上传下载

10) 再说ExtJs与WCF之间的跨域访问

11) [添砖加瓦]:ExtJS+WCF+LINQ打造全功能Grid

12) 【封装】WCF+LINQ+ExtJS做更简单的Grid

 

   前面几篇文章分别介绍了用ExtJs+WCF+LINQ实现分页,排序,跨域查询等基本功能,本文便对上面的Grid进行进一步扩展。新扩展的Grid将包括以下功能:

  1. 分页功能
  2. 远程排序功能
  3. 添加新纪录功能
  4. 批量删除功能
  5. 批量更新功能

并且,如题目中介绍一致,这个全功能Grid结合了下面几种技术:

  1. WCF,而且采用Web Model方式。
  2. ExtJs
  3. LINQ

这三种都是比较新的技术,尤其是完全采用 Rest方式使得ExtJS与WCF进行比较复杂的交互,这个环节实现原理非常简单,就是采用JSON格式在前后台交互数据,但涉及到的细节还是比较多 的。LINQ虽然很火,被人说得神乎其神,使用起来也是有诸多要注意的环节。ExtJS中有关UI的细节也存在不少,总结一下,本文中主要解决了如下几条 难题:

涉及到ExtJs的包括如下几点:

  1. 在ExtJs的Grid中格式化时间显示问题
  2. 在ExtJs中添加自定义控件列问题
  3. 设定ExtJs中列主键的问题
  4. 将Ext.data.Record数组格式化成JSON字符串问题
  5. 用Ext.util.JSON.encode序列化javascirpt对象中有中文时候的乱码问题
  6. 在ExtJs中提交的时候显示进度条的问题
  7. 在对Grid进行多次编辑后,如何取得编辑和数据项的问题

涉及到WCF的包括如下几点:

  1. 如何返回能用于ExtJs中Grid分页显示的数据契约对象集合。
  2. 如何返回原始数据格式的数据(原始数据格式极大的提高了WCF的灵活度,为上传下载,跨域等问题提供了保证)
  3. 如何获取通过POST方式传递的复杂数据。
  4. 如何将客户端传递过来的JSON字符串序列化为数据契约的对象

涉及到LINQ的包括如下几点

  1. 如何实现数据的分页查询
  2. 如何动态的对数据字段进行排序
  3. 如何添加数据
  4. 如何批量删除数据
  5. 如何批量更新数据,批量更新数据遇到并发冲突的时候,如何解决。

上面这些问题,在本文所实现的实例项目中均有所体现。而且实现本文这个项目实例,还需要注意如下几点:

  1. 因为本文没有涉及到级联关系,为了添加,修改,删除等操作成功进行,需要将示例数据库AdventureWorks中数据表Product中的全部关系删除
  2. 因为在ExtJs与WCF交互中, DataContractJsonSerializer 不支持DateTime的序列化,查阅了一下MSDN,不是DataContractJsonSerializer不支持序列化DateTime,它能够 与Asp.Net Ajax之间对DateTime数据进行交互,但经过试验对ExtJs却不行,看了一下,好像应该是缺少转义字符的原因。试图反格式化 Ext.util.JSON.encode后产生的JSON字符串会产生如下的异常:

    所以本文实例中将数据契约Product中的DateTime类型均转换为了String类型

  3. 经过第二步的处理之后,利用LINQ对数据进行更新却说什么也不能成功了,总是有数据并发的问题,解决办法是设置Product中的这几个字段的UpdateCheck=UpdateCheck.Never

下面看下最后实现的Grid运行效果截图:

  1. 分页排序效果

    加载中

    加载完毕

    排序

  2. 新增记录

  3. 批量删除

  1. 批量修改

 

 而且,本文的项目中抽象出了几个常用的js功能方法

1) 格式化数组对象为JSON

2) 显示进度条

3) 简化的form提交

 

ExtHelper.js

 

示例项目: http://cid-90a19c48cf229168.skydrive.live.com/self.aspx/%e5%8d%9a%e5%ae%a2%e5%9b%ad%e4%bb%a3%e7%a0%81%e7%a4%ba%e4%be%8b/ExtJs%7C_Wcf%7C_Linq%7C_ALLFeatureGrid.rar

 

8月5日更新内容:

1) 增加了筛选功能

2)增加了刷新功能

3)增加了Excel导出功能

ExtJs下有强大的筛选功能,并且根据数据类型,可以分为如下几种筛选器:

1) StringFilter

2) NumericFilter

3) DateFilter

4) BooleanFilter

5) ListFilter

它们都派生于Filter,用于ExtJsGrid的条件查询上,效果非常棒。

根据语言需要,我将里面的代码改善了下,以支持中文,下面是运行截图:

 

 extjsgrid1.jpg" border="0" height="455" width="614" />

  extjsgrid2.jpg" border="0" height="455" width="617" />

从上图可以看出,对于NumericFilter来说,刷选方式会有三种大于,小于,等于这样非常方便的对数字类型数据进行筛选,如果有in就更好了

更重要的是还支持多字段筛选,下面在上图的基础上做进一步筛选

 

extjsgrid3.jpg" border="0" height="457" width="617" />

extjsgrid4.jpg" border="0" height="458" width="989" />

而且,默认条件下DataFilter中显示的前后中,分别为before,after,on,BooleanFilter中显示也只是yes,no,我对其做了扩展。

 

上面的筛选功能记住,有时候进行了多次筛选之后,可能对刷选条件比较混乱,此时点击菜单中筛选即可清空刷选,重新加载数据

 

extjsgrid5.jpg" border="0" height="460" width="614" /> 

最重要,本次增加了导出Excel功能,而且该功能相当智能,相当先进,它基于xml,完全不需要组件。 前后台还能有机配合实现前台那几列就导出那几列,该导出的数据导出,不该导出的按钮列,多选列自动排除在外。导出的时候Filter依然有效,前台显示是 分页的,但后台导出却是没有分页整个列表应该显示的数据。导出的数据,经过测试,没有乱码现象

extjsgrid6.jpg" border="0" height="460" width="618" />

extjsgrid7.jpg" border="0" height="305" width="426" />

extjsgrid8.jpg" border="0" height="534" width="705" />

进行刷选后,导出的效果为:

extjsgrid9.jpg" border="0" height="165" width="557" />

具体实现方法,因为代码较多,涉及到的内容比较凌乱,不便一一说明,感兴趣的可以在实例项目中下载

 

8月5日修正版:http://cid-90a19c48cf229168.skydrive.live.com/self.aspx/%e5%8d%9a%e5%ae%a2%e5%9b%ad%e4%bb%a3%e7%a0%81%e7%a4%ba%e4%be%8b/ExtJs%7C_Wcf%7C_Linq%7C_AllFeatureGrid%7C_Edited%7C_0805.rar 

 

8月9日更新

1) 将Excel导出扩展为两种 a)只导出当前页 b)导出全部

 

效果图:

 

0809修正后项目:

http://files.cnblogs.com/jillzhang/ExtJs_Wcf_Linq_AllFeatureGrid_Edited_0809.rar 



http://www.niftyadmin.cn/n/1412930.html

相关文章

使用Docker构建支持中文字体的Java镜像

在构建镜像的过程中安装字体管理器和中文字体 构建jre镜像,参考这篇文章: Docker构建自定义的Java镜像:https://blog.csdn.net/zimou5581/article/details/9402274 如何安装中文字体,参考这篇文章 如何给dcoker容器里的alpine系统…

oracle日期处理完全版

TO_DATE格式复制内容到剪贴板代码:Day:dd number 12dy abbreviated friday spelled out fridayddspth spelled out, ordinal twelfthMonth:mm number 03mon abbreviated marmonth spelled out marchYear:yy two digits 98yyyy four digits 199824小时格式下时间范围为&#xff…

C -- OC with RunTime

前言 本来打算写一篇关于runtime的学习总结,无奈长篇大论不是我的风格,就像写申论一样痛苦,加之网上关于tuntime的文章多如牛毛,应该也够童子们学习的了,今天就随便聊聊我的理解吧。 runtime是什么 对于初学者&#xf…

Hive小文件处理

小文件是如何产生的: 动态分区插入数据的时候,会产生大量的小文件,从而导致map数量的暴增数据源本身就包含有大量的小文件reduce个数越多,生成的小文件也越多小文件的危害: 从HIVE角度来看的话呢,小文件越多…

深入浅出Spring Security(一):三句话解释框架原理

三句话解释框架原理 整个框架的核心是一个过滤器,这个过滤器名字叫springSecurityFilterChain类型是FilterChainProxy核心过滤器里面是过滤器链(列表),过滤器链的每个元素都是一组URL对应一组过滤器WebSecurity用来创建FilterCha…

Qt之坐标系统

简述 坐标系统由 QPainter 类控制,再加上 QPaintDevice 和 QPaintEngine,就形成了 Qt 的绘图体系。 QPainter:用于执行绘图操作QPaintDevice:二维空间的抽象层,可以使用 QPainter 在它上面进行绘制。QPaintEngine&…

oracle 日期经常用到的转换

1、转换函数与date操作关系最大的就是两个转换函数: to_date(),to_char()to_date() 作用将字符类型按一定格式转化为日期类型:具体用法:to_date(2004-11-27,yyyy-mm-dd),前者为字符串,后者为转换日期格式,注意,前后两者…

BUAA_OO_UML_OO总结

(1)总结本单元两次作业的架构设计 对于uml每个类型都进行构建,发现class和inference可以公用 继承和接口实例化数据结构一样 然后进行构造首先将所有模型输入都存入 参数传入函数 函数带入类或者接口 构建关联关系,构建接口实现…