有时候我们使用Ajax链接一般处理程序需要返回多个值,然而这些数据并非在一个查询表内,此时便想到构造一个虚拟的DataTable,这样就可以返回多个值了(当然有很多办法,这是其中一种 )。

首先我们需要准备一个 script 和一个 ashx 文件。

在script中写一个ajax用于接收返回来的数据,代码如下。

<script type="text/javascript">
        $(function () {
            $.ajax({
                type: "post",                          //提交方式
                url: "/ashx/PersonnelRegistrationForm.ashx",        //一般处理程序的路径
                data: { corpName: corpName, corpCode: corpCode },           //向后台传入的值
                success: function (data) {              //返回成功后将要做的事,这里是返回一个表
                    var datainfo = $.parseJSON(data);            alert(datainfo[0].OrderNo);             alert(datainfo[0].RowGuid);                    alert(datainfo[0].ResultNum);
                },
                error: function () {
                    alert('系统发生错误');
                }
            });
        })
    </script>

然后在名为PersonnelRegistratinForm一般处理程序进行数据处理,然后构造所需要的值将其返回。

        #region 构造返回的表
            DataTable table = new DataTable();      //构造表
            DataColumn column1 = new DataColumn("ResultNum", Type.GetType("System.Int32"));  //构造列及所对应的类型
            DataColumn column2 = new DataColumn("OrderNo", Type.GetType("System.String"));
            DataColumn column3 = new DataColumn("RowGuid", Type.GetType("System.String"));
            table.Columns.Add(column1);             //将列添加到table表中
            table.Columns.Add(column2);
            table.Columns.Add(column3);
            DataRow dr = table.NewRow();            //table表创建行
            dr["ResultNum"] = person_result;
            dr["OrderNo"] = OrderNo;
            dr["RowGuid"] = t_ROWGUID;
            table.Rows.Add(dr);                     //将数据加入到table表中

            string json = SerializerHelper.ToJsonString(table);     //序列化json对象
            context.Response.Write(json);
            context.Response.End();
            #endregion

构造table时可以使用简便写法:

            DataTable table = new DataTable();      //构造表
            table.Columns.Add("ResultNum", Type.GetType("System.Int32"));
            table.Columns.Add("OrderNo", Type.GetType("System.String"));
            table.Columns.Add("RowGuid", Type.GetType("System.String"));
            DataRow dr = table.NewRow();            //table表创建行
            dr["ResultNum"] = person_result;
            dr["OrderNo"] = OrderNo;
            dr["RowGuid"] = t_ROWGUID;
            table.Rows.Add(dr);                     //将数据加入到table表中        

 这样前台的ajax就可以获取到返回过去的table了。当然别忘记引用命名空间

using System.Data;
using System.Data.SqlClient;
using System.Text;

.NET 构造DataTable返回多个json值的更多相关文章

  1. .NET 构造Class返回多个json值

    上次总结使用DataTable返回多个值,后来看到一个小哥的返回方式和我的有所不同,便留意了一下.原来他构造一个Class,而我构造的是一个Table. 首先说说两者的区别:拿student举例,st ...

  2. Nginx根据用户请求的不同参数返回不同的json值

    用户请求url:http://localhost:8000/getconfig?v=1.03.01,根据参数v=1.03.01或者其他的值返回不同的json值.如果用户请求不带该参数,则返回默认的js ...

  3. Mysql 返回JSON值属性的函数 (五)

    本节中的函数返回JSON值的属性. JSON_DEPTH(json_doc) 返回JSON文档的最大深度.NULL如果参数为,则 返回 NULL.如果参数不是有效的JSON文档,则会发生错误. 一个空 ...

  4. ashx将datatable返回json数据

    1.直接使用JsonConvert.SerializeObject().将datatable放入  输出字符串 下面是测试:用webform+ashx作为接口. public class GetJso ...

  5. .net和MVC中的json值和List<T>和DataTable的一些转换

    1.List<T>集合转换为Json值 List<ReportModel> dtList = new List<ReportModel>(); JsonResult ...

  6. EasyUI - 一般处理程序 返回 Json值

    使用 一般处理程序(ashx)返回Json值. 原始Json数组的格式: [ { ", "name":"张三", "sex":&q ...

  7. JSON.stringify()方法是将一个javascript值(对象或者数组)转换成为一个JSON字符串;JSON.parse()解析JSON字符串,构造由字符串描述的javascript值或对象

    JSON.stringify()方法是将一个javascript值(对象或者数组)转换成为一个JSON字符串:JSON.parse()解析JSON字符串,构造由字符串描述的javascript值或对象

  8. C#中当服务器返回的数据json中key的值为数字类型,解决方案

    客户端向服务器发送请求后,服务器返回了一个json格式的字符串但是格式中key的值有些事数字{"1000":"55555"}; 类似这种格式的话就不能直接转化成 ...

  9. DataTable ,XML和JSON相互转化

    网上搜集的,保留下来了,有需要的拿去!private string DataTable2Xml(DataTable dt) { StringBuilder xmlBuilder = new Strin ...

随机推荐

  1. 关于.gitignore无法过滤某些文件

    .gitignore文件用于忽略那些无需添加到版本管理的文件.但最近发现有些文件即使被加入到了.gitignore文件中,push时仍会被上传. 原因:如果某些文件已经被纳入了版本管理中,就算是在.g ...

  2. C++重写(覆盖)、重载、重定义、

    总结: 重写(覆盖)override 是指派生类函数重写(覆盖)基类函数 不同的范围,分别位于基类和派生类中 函数的名字相同 参数相同 基类函数必须有virtual关键字 重载overload 成员函 ...

  3. 386. Lexicographical Numbers 输出1到n之间按lexico排列的数字序列

    [抄题]: Given an integer n, return 1 - n in lexicographical order. For example, given 13, return: [1,1 ...

  4. time模块的使用

    https://www.cnblogs.com/jimmy-share/p/10605575.html import time 一.方法汇总: time.sleep():定时函数 time.time( ...

  5. 阮一峰大神的快排?刚才还在纠结sort()的我!真是个小傻瓜

    看到这个标题之后 我毫不犹豫的点进去了 趁现在不忙我赶紧把代码写到了我的小本本上好好研究研究 (写的就不放进来了 有点丑) 研究了下  第一反应 明明能用sort()解决的 为什么非要写这么一大串 但 ...

  6. Java代码获取spring 容器的bean几种方式

    一.目的 写了一个项目,多个module,然后想在A模块中实现固定的config注入,当B模块引用A时候,能够直接填写相对应的配置信息就行了.但是遇到一个问题,B引用A时候,A的配置信息总是填充不了, ...

  7. Difference between MB Star C3 and MB Star C4

    Many times ago, i saw a blog about MB sd connect C4 for benz, the author said he like this tool very ...

  8. rsync 定时备份<crontab+backrsync.sh> 简陋版

    数据需要定时的备份至其它的目录中,但是备份之前检查检查一下是否有rsync正在运行,曾经因为数据过大,导致有很多rsync进程在跑,然后服务器有出现卡死的现象.最终写了一条bash,先检查一下是否有这 ...

  9. CDH 安装

    CDH 安装 市场上免费大数据框架主要有三个版本,原生的 Apache 版本,Cloudera(https://www.cloudera.com/) 公司研发的(Cloudera Distributi ...

  10. wince 6.0 汉字乱码

    CStdioFile file; file.Open(…); file.WriteString(_T("abc你好"));//只能写入abc 解决办法: 使用setlocale语句 ...