.NET 构造DataTable返回多个json值

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

       有时候我们使用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;

 

目录
相关文章
|
8月前
|
JSON 开发框架 JavaScript
【Azure Developer】使用.Net Core解析JSON的笔记
【Azure Developer】使用.Net Core解析JSON的笔记
|
10月前
|
JSON 开发框架 API
【推荐100个unity插件之20】一个强大的JSON处理库——Newtonsoft.Json(也称为Json.NET)
【推荐100个unity插件之20】一个强大的JSON处理库——Newtonsoft.Json(也称为Json.NET)
770 0
|
10月前
|
JSON 数据格式 微服务
.NET下 支持大小写不敏感的JSON Schema验证方法
有很多应用程序在验证JSON数据的时候用到了JSON Schema。 在微服务架构下,有时候各个微服务由于各种历史原因,它们所生成的数据对JSON Object属性名的大小写规则可能并不统一,它们需要消费的JSON数据的属性名可能需要大小写无关。 遗憾的是,目前的JSON Schema没有这方面的标准,标准中都是大小写敏感的。在类似上述情况下,这给使用JSON Schema进行数据验证造成了困难。
|
11月前
|
消息中间件 JSON NoSQL
知识巩固源码落实之7:json协议使用cjson的构造和解析
知识巩固源码落实之7:json协议使用cjson的构造和解析
110 0
|
11月前
|
JSON 开发框架 .NET
ASP.NET Core Web API设置响应输出的Json数据格式的两种方式
ASP.NET Core Web API设置响应输出的Json数据格式的两种方式
238 0
|
数据库 C#
C#,.net,winform导入Excel功能以及下载Excel文件到本地,并使用SqlBulkCopy把DataTable类型的数据写入到sqlserver数据库中
C#,.net,winform导入Excel功能以及下载Excel文件到本地,并使用SqlBulkCopy把DataTable类型的数据写入到sqlserver数据库中
131 0
|
SQL JSON 开发框架
.NET 中的 Json 使用体验
本文主要总结介绍.NET 中的对 Json 数据使用在使用过程中的关于编码、循环引用、时间格式化的一些问题
219 0
.NET 中的 Json 使用体验
|
JSON Linux API
windows python flask返回json数据
windows python flask返回json数据
windows python flask返回json数据
|
JSON 前端开发 Java
SpringMVC 使用@ResponseBody返回json 中文乱码
SpringMVC 使用@ResponseBody返回json 中文乱码
281 0
SpringMVC 使用@ResponseBody返回json 中文乱码
|
存储 JSON JavaScript
.NET MVC第九章、Web Api Json序列化与反序列化
.NET MVC第九章、Web Api Json序列化与反序列化
235 0
.NET MVC第九章、Web Api Json序列化与反序列化