封装jQuery表格插件jqGrid,控件化jqGrid(二):显示

接上一篇http://www.cnblogs.com/bestfc/archive/2010/06/07/1753216.html

本文编码数据提供类

1,创建AjaxData类,继承接口IHttpHandler,实现其方法public void ProcessRequest(HttpContext context)和参数public bool IsReusable

2,使用SqlHelper类与数据库进行交互(在MVC中可以使用entity framework提供数据,当然在MVC中,最好就不要使用服务器控件了,可以直接输出字符串)

3,在AjaxData类中,创建两个方法

public string jsonString(HttpContext context)用于处理接收到的基本数据,最后经过以下方法返回数据的json字符串

其代码如下:

 

 

其中使用到了SqlHelper.cs提供的SQL2005存储过程。

public string DataTableToJson(DataTable dt, int page, int total, int records, XmlDocument xmlDoc)用于DataTable转化为jqGrid格式的字符串,其代码如下:

复制代码


从以上两个方法可以看到,传过来的值中,自定义了一个QueryString,tablename用于取得对应的配置文件,也可以使用反射的方法去提供数据,但是相对于来说,很不灵活。

4,在ProcessRequest方法中编码对于前台的动作反馈相应的数据,以下是部分代码:


传过来的值中,自定义了一个QueryString,action用于判别前台传过来的动作,用于后面还有的查询,编辑,修改,删除等功能。

这里只反馈数据用于前台的显示。

 

这样,AjaxData完成。

接下来可以建立一个前台项目,为中上面的方法中获取数据,在web.config声明httpHandlers:

复制代码

 

位于system.web节点下,这样,就将页面请求定位到了AspJqGrid的AjaxData类

另外,在控件代码中加入了[assembly:TagPrefix("AspJqGrid","AllenJqGrid")],在web.config中声明全局

第一步的Hello World显示方面的工作就完成了,下一篇开始编码查询功能

这样,在页面中添加<AllenJqGrid:JqGrid ID="MyJqGrid" runat="server" TableName="diamond" />

复制代码

 

复制代码
posted @   黑曜石  阅读(6523)  评论(7编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
历史上的今天:
2009-06-08 Jquery UI dialog 详解 (中文)
2009-06-08 jquery ui according详解(中文)
2009-06-08 jquery ui tabs详解(中文)
点击右上角即可分享
微信分享提示