写在前面
悉数手打,没有过剩的话,悉数干货,基本上用到的我就记录了。
一、什么是JSON
JSON:JavaScript Object Notation,是一种轻量级的数据交互花样,重要用于数据传输。
二、JSON语法划定规矩
1、数据由键值对(映照)关联示意,运用 “:” 示意;
例子:"name" : "赵大"。
2、数据之间运用 “,” 分开;
例子:"name" : "赵大", "age" : "27"。
3、数据映照的鸠合(对象)用 “{}” 包括;
例子:一条门生数据对象:
{"id" : "1", "name" : "赵大", "age" : "27", "gender" : "男"}
4、并列数据的鸠合(对象的数组情势)用 “[]”包括,之间用 “,”分开;
例子:两条门生数据对象数组:
[{"id" : "1", "name" : "赵大", "age" : "27", "gender" : "男"}, {"id" : "2", "name" : "钱二", "age" : "27", "gender" : "男"}]
三、JSON数据中的数据类型
数字 (整数或许浮点数)
字符串(在双引号中)
布尔值(True或False)
数组 (在[]中)
对象 (在{}中)
NULL
四、JSON花样数据的数据表现
经由过程JSON的语法划定规矩可知,JSON数据平常有以下几种表现情势:
1、单对象;
2、对象鸠合(数组);
3、1和2的组合:嵌套;
4、纯字符串;
五、C#.NET与JSON
在C#.NET环境下有对JSON序列化和反序列化支撑的组件,也有第三方的组件,
.NET支撑的有 JavaScriptSerializer 类和 DataContractJsonSerializer 类,
第三方支撑的有 Json.net(newtonsoft.json)等。
1、运用 JavaScriptSerializer 类对JSON数据序列化和反序列化:
首先得在援用中援用:System.Web.Extentions.dll
类文件中做援用:using System.Web.Script.Serialization;
Dictionary<string, string> stu = new Dictionary<string, string>(); stu.Add("id", "1"); stu.Add("name", "赵大"); stu.Add("age", "27"); stu.Add("gender", "男"); JavaScriptSerializer js = new JavaScriptSerializer(); string stuJson = js.Serialize(stu); Console.WriteLine("运用 JavaScriptSerializer 类序列化获得JSON花样数据:"); Console.WriteLine(stuJson); 示例:JSON单对象序列化
string deJson = stuJson; Dictionary<string, string> deStu = js.Deserialize<Dictionary<string, string>>(deJson); Console.WriteLine("运用 JavaScriptSerializer 类将JSON花样数据反序列化指定类:"); foreach (string s in stu.Keys) { Console.WriteLine(s.ToString() + "=" + stu[s].ToString()); } Console.ReadLine(); 示例:JSON单对象反序列化
运转效果:
2、运用第三方支撑的 Json.net(newtonsoft.json)类库对JSON数据序列化和反序列化:
六、JavaScript与JSON
1、JavaScript中自定义JSON字符串并剖析;
例子:门生赵大信息:
function myJson() { var stu = { "id": "1", "name": "赵大", "age": "27", "gender": "男", "school": { "class": "03", "teacher": "赵大的先生" } }; alert("id=" + stu.id + ", " + "name=" + stu.name + ", " + "age=" + stu.age + ", " + "gender=" + stu.gender); }
效果图:
能够看到自定义的JSON字符串后,在运用stu这个对象能够自动识别为成员变量了。
2、从背景传入的JSON数据经由过程剖析后转化为JSON数据对象:
例子:门生赵大信息(这里的Ajax要求用JQuery处置惩罚了):
$(document).ready(function () { $.ajax({ url: "AjaxWeb.ashx", type: "GET", dataType: "JSON", success: function (data) { var stu = JSON.parse(data); alert("id=" + stu.id + ", " + "name=" + stu.name + ", " + "age=" + stu.age + ", " + "gender=" + stu.gender + ", " + "teacher=" + stu.school["teacher"]); }, error: function (e) { alert(e.toString()); } }) }) 从背景猎取JSON字符串后转化为JSON对象
public void ProcessRequest(HttpContext context) { context.Response.Write(myJson2()); } private string myJson2() { string json = " {\"id\": \"1\", \"name\": \"赵大\", \"age\": \"27\", \"gender\": \"男\", \"school\": { \"class\": \"03\", \"teacher\": \"赵大的先生\" }}"; JavaScriptSerializer js = new JavaScriptSerializer(); json = js.Serialize(json); return json; } 背景处置惩罚文件代码
效果图:
Chrome下F12开发人员东西调试效果图:
以上就是简朴引见C#.NET、JavaScript和JSON(图文)的细致内容,更多请关注ki4网别的相干文章!