Newtonsoft.Json(Json.net) 的使用皇牌天下投注网

来源:http://www.prospettivedarte.com 作者:计算机教程 人气:107 发布时间:2019-05-11
摘要: Newtonsoft.Json(Json.net) 的使用 在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:ListT、DataTable转换为Json格式。特别在使用Extjs框架

 Newtonsoft.Json(Json.net) 的使用

在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>、DataTable转换为Json格式。特别在使用Extjs框架的时候,Ajax异步请求的数据格式就是Json。鉴于此,我今天来分享将DataTable 转换成 Json的3种方法。换句话说如何在ASP.NET将一个DataTable序列化为 Json数组。或者如何从一个DataTable返回一个Json字符串。这篇文章将采用StringBuilder,JavaScriptSerializer和 Json.Net DLL (Newtonsoft) 这3种方法实现这一目标。

//Newtonsoft.Json.dll
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
public static class JConvert
{
    private static IsoDateTimeConverter datetimeimeFormat;
    static JConvert()
    {
        datetimeimeFormat = new IsoDateTimeConverter();
        datetimeimeFormat.DateTimeFormat = "yyyy-MM-dd HH:mm:ss";
    }

    public static string Serialize(object value)
    {
        return  JsonConvert.SerializeObject(value, Formatting.Indented, datetimeimeFormat);
    }

    public static T Deserialize<T>(string value)
    {
        return JsonConvert.DeserializeObject<T>(value);
    }
}

Json概述

 

JavaScript Object Notation (Json)是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。这些特性使Json成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。Json采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯,包括C、C 、C#、Java、JavaScript、Perl、Python等等。

这些特性使Json成为一种理想的数据交换语言。因此 基于AJAX应用程序,Json已经成为一种用于数据交换的流行格式。总之,Json是一种存储和交换数据的语法,易于操作,也是除XML之外的不二之选。

步骤:

首先我们从Microsoft SQL Server 获取数据到DataTable,也可以给DataTable动态添加行。代码如下:

 private DataTable getData()
    {
        DataTable dt = new DataTable();
        dt.Columns.Add("编号", typeof(Int32));
        dt.Columns.Add("姓名", typeof(string));
        dt.Columns.Add("性别", typeof(string));
        dt.Columns.Add("学历", typeof(string));
        dt.Rows.Add(1, "王超", "男", "本科");
        dt.Rows.Add(2, "周丽", "女", "专科");
        dt.Rows.Add(3, "李娟", "女", "专科");
        dt.Rows.Add(4, "杨明", "男", "硕士");
        dt.Rows.Add(5, "张德", "男", "本科");
        return dt;
    }

下面开始通过每一种方法实现DataTable转换成 Json 对象。

方法1:使用StringBuilder

这是Json样本数据的样子: {"姓名 ":"张三", "年龄":"30"}。Json里用花括号保存对象,它可以包含多个名称/值对。所以使用StringBuilder我们可以创建一个类似的Json字符串。

由于要使用StringBuilder类,我们首先需要导入System.Text命名空间,如下:

using System.Text; 

下面的代码将生成一个Json字符串,遍历DataTable的行和列,获取数据,添加到一个StringBuilder对象 JsonString,然后返回这个对象。

public string DataTableToJson(DataTable table)
    { 
        var JsonString = new StringBuilder();
        if (table.Rows.Count > 0)
        {
            JsonString.Append("[");
            for (int i = 0; i < table.Rows.Count; i  )
            {
                JsonString.Append("{");
                for (int j = 0; j < table.Columns.Count; j  )
                {
                    if (j < table.Columns.Count - 1)
                    {
                        JsonString.Append("""   table.Columns[j].ColumnName.ToString()   "":"   """   table.Rows[i][j].ToString()   "",");
                    }
                    else if (j == table.Columns.Count - 1)
                    {
                        JsonString.Append("""   table.Columns[j].ColumnName.ToString()   "":"   """   table.Rows[i][j].ToString()   """);
                    }
                }
                if (i == table.Rows.Count - 1)
                {
                    JsonString.Append("}");
                }
                else
                {
                    JsonString.Append("},");
                }
            }
            JsonString.Append("]");
        }
        return JsonString.ToString();   
    }

本文由皇牌天下投注网发布于计算机教程,转载请注明出处:Newtonsoft.Json(Json.net) 的使用皇牌天下投注网

关键词:

最火资讯