JSON詳解(轉)

來源:互聯網
上載者:User

標籤:開始   convert   mes   label   關鍵字   birt   esc   on()   bar   

JSON的全稱是”JavaScript Object Notation”,意思是JavaScript對象標記法,它是一種基於文本,獨立於語言的輕量級資料交換格式。XML也是一種資料交換格式,為什麼沒有選擇XML呢?因為XML雖然可以作為跨平台的資料交換格式,但是在JS(JavaScript的簡寫)中處理XML非常不方便,同時XML標記比資料多,增加了交換產生的流量,而JSON沒有附加的任何標記,在JS中可作為對象處理,所以我們更傾向於選擇JSON來交換資料。這篇文章主要從以下幾個方面來說明JSON。

1,JSON的兩種結構
2,認識JSON字串
3,在JS中如何使用JSON
4,在.NET中如何使用JSON
5,總結

回到頂部JSON的兩種結構

JSON有兩種表示結構,對象和數組。
對象結構以”{”大括弧開始,以”}”大括弧結束。中間部分由0或多個以”,”分隔的”key(關鍵字)/value(值)”對構成,關鍵字和值之間以”:”分隔,文法結構如代碼。

{    key1:value1,    key2:value2,    ...}

其中關鍵字是字串,而值可以是字串,數值,true,false,null,對象或數組

數組結構以”[”開始,”]”結束。中間由0或多個以”,”分隔的值列表組成,文法結構如代碼。

[    {        key1:value1,        key2:value2     },    {         key3:value3,         key4:value4       }]
回到頂部認識JSON字串

之前我一直有個困惑,分不清一般字元串,json字串和json對象的區別。經過一番研究終於給弄明白了。比如在js中。

字串:這個很好解釋,指使用“”雙引號或’’單引號包括的字元。例如:var comStr = ‘this is string‘;
json字串:指的是符合json格式要求的js字串。例如:var jsonStr = "{StudentID:‘100‘,Name:‘tmac‘,Hometown:‘usa‘}";
json對象:指符合json格式要求的js對象。例如:var jsonObj = { StudentID: "100", Name: "tmac", Hometown: "usa" };

回到頂部在JS中如何使用JSON

JSON是JS的一個子集,所以可以在JS中輕鬆地讀,寫JSON。讀和寫JSON都有兩種方法,分別是利用”.”操作符和“[key]”的方式。
我們首先定義一個JSON對象,代碼如下。

var obj = {            1: "value1",            "2": "value2",            count: 3,            person: [ //數組結構JSON對象,可以嵌套使用                        {                            id: 1,                            name: "張三"                        },                        {                            id: 2,                            name: "李四"                        }                   ],            object: { //對象結構JSON對象                id: 1,                msg: "對象裡的對象"                }        };

1,從JSON中讀資料

function ReadJSON() {            alert(obj.1); //會報語法錯誤,可以用alert(obj["1"]);說明數字最好不要做關鍵字            alert(obj.2); //同上            alert(obj.person[0].name); //或者alert(obj.person[0]["name"])            alert(obj.object.msg); //或者alert(obj.object["msg"])        }

2,向JSON中寫資料

比如要往JSON中增加一條資料,代碼如下:

function Add() {             //往JSON對象中增加了一條記錄            obj.sex= "男" //或者obj["sex"]="男"        }

增加資料後的JSON對象

3,修改JSON中的資料

我們現在要修改JSON中count的值,代碼如下:

function Update() {            obj.count = 10; //或obj["count"]=10        }

修改後的JSON。

4,刪除JSON中的資料

我們現在實現從JSON中刪除count這條資料,代碼如下:

function Delete() {            delete obj.count;        }

刪除後的JSON

可以看到count已經從JSON對象中被刪除了。

5,遍曆JSON對象

可以使用for…in…迴圈來遍曆JSON對象中的資料,比如我們要遍曆輸出obj對象的值,代碼如下:

function Traversal() {            for (var c in obj) {                console.log(c + ":", obj[c]);            }        }

程式輸出結果為:

回到頂部在.NET中如何使用JSON

說到在.net中使用JSON,就不得不提到JSON.NET,它是一個非常著名的在.net中處理JSON的工具,我們最常用的是下面兩個功能。

1,通過序列化將.net對象轉換為JSON字串

在web開發過程中,我們經常需要將從資料庫中查詢到的資料(一般為一個集合,列表或數組等)轉換為JSON格式字串傳回用戶端,這就需要進行序列化,這裡用到的是JsonConvert對象的SerializeObject方法。其文法格式為:JsonConvert.SerializeObject(object),代碼中的”object”就是要序列化的.net對象,序列化後返回的是json字串。

比如,現在我們有一個TStudent的學生表,表中的欄位和已有資料

從表中我們可以看到一共有五條資料,現在我們要從資料庫中取出這些資料,然後利用JSON.NET的JsonConvert對象序列化它們為json字串,並顯示在頁面上。C#代碼如下

protected void Page_Load(object sender, EventArgs e)        {            using (L2SDBDataContext db = new L2SDBDataContext())            {                List<Student> studentList = new List<Student>();                var query = from s in db.TStudents                            select new {                                 StudentID=s.StudentID,                                Name=s.Name,                                Hometown=s.Hometown,                                Gender=s.Gender,                                Brithday=s.Birthday,                                ClassID=s.ClassID,                                Weight=s.Weight,                                Height=s.Height,                                Desc=s.Desc                            };                foreach (var item in query)                {                    Student student = new Student { StudentID=item.StudentID,Name=item.Name,Hometown=item.Hometown,Gender=item.Gender,Brithday=item.Brithday,ClassID=item.ClassID,Weight=item.Weight,Height=item.Height,Desc=item.Desc};                    studentList.Add(student);                }                lbMsg.InnerText = JsonConvert.SerializeObject(studentList);            }        }

輸出結果

我們可以看到,資料庫中的5條記錄全部取出來並轉化為json字串了。

 

2,使用LINQ to JSON定製JSON資料

使用JsonConvert對象的SerializeObject只是簡單地將一個list或集合轉換為json字串。但是,有的時候我們的前端架構比如ExtJs對服務端返回的資料格式是有一定要求的,比如下面的資料格式,這時就需要用到JSON.NET的LINQ to JSON,LINQ to JSON的作用就是根據需要的格式來定製json資料。

比如經常用在分頁的json格式如代碼:

{     "total": 5, //記錄總數    "rows":[        //json格式的資料列表    ]}

使用LINQ to JSON前,需要引用Newtonsoft.Json的dll和using Newtonsoft.Json.Linq的命名空間。LINQ to JSON主要使用到JObject, JArray, JProperty和JValue這四個對象,JObject用來產生一個JSON對象,簡單來說就是產生”{}”,JArray用來產生一個JSON數組,也就是”[]”,JProperty用來產生一個JSON資料,格式為key/value的值,而JValue則直接產生一個JSON值。下面我們就用LINQ to JSON返回上面分頁格式的資料。代碼如下:

protected void Page_Load(object sender, EventArgs e)        {            using (L2SDBDataContext db = new L2SDBDataContext())            {                //從資料庫中取出資料並放到列表list中                List<Student> studentList = new List<Student>();                var query = from s in db.TStudents                            select new                            {                                StudentID = s.StudentID,                                Name = s.Name,                                Hometown = s.Hometown,                                Gender = s.Gender,                                Brithday = s.Birthday,                                ClassID = s.ClassID,                                Weight = s.Weight,                                Height = s.Height,                                Desc = s.Desc                            };                foreach (var item in query)                {                    Student student = new Student { StudentID = item.StudentID, Name = item.Name, Hometown = item.Hometown, Gender = item.Gender, Brithday = item.Brithday, ClassID = item.ClassID, Weight = item.Weight, Height = item.Height, Desc = item.Desc };                    studentList.Add(student);                }                //基於建立的list使用LINQ to JSON建立期望格式的JSON資料                lbMsg.InnerText = new JObject(                        new JProperty("total",studentList.Count),                        new JProperty("rows",                                new JArray(                                        //使用LINQ to JSON可直接在select語句中產生JSON資料對象,無須其它轉換過程                                        from p in studentList                                        select new JObject(                                                new JProperty("studentID",p.StudentID),                                                new JProperty("name",p.Name),                                                new JProperty("homeTown",p.Hometown)                                            )                                    )                            )                    ).ToString();            }        }

輸出結果為:

 

3,處理用戶端提交的JSON資料

用戶端提交過來的資料一般都是json字串,有了更好地進行操作(物件導向的方式),所以我們一般都會想辦法將json字串轉換為json對象。例如用戶端提交了以下數組格式json字串。

[    {StudentID:"100",Name:"aaa",Hometown:"china"},    {StudentID:"101",Name:"bbb",Hometown:"us"},    {StudentID:"102",Name:"ccc",Hometown:"england"}]

在服務端就可以使用JObject或JArray的Parse方法輕鬆地將json字串轉換為json對象,然後通過對象的方式提取資料。下面是服務端代碼。

protected void Page_Load(object sender, EventArgs e)        {            string inputJsonString = @"                [                    {StudentID:‘100‘,Name:‘aaa‘,Hometown:‘china‘},                    {StudentID:‘101‘,Name:‘bbb‘,Hometown:‘us‘},                    {StudentID:‘102‘,Name:‘ccc‘,Hometown:‘england‘}                ]";            JArray jsonObj = JArray.Parse(inputJsonString);            string message = @"<table border=‘1‘>                    <tr><td width=‘80‘>StudentID</td><td width=‘100‘>Name</td><td width=‘100‘>Hometown</td></tr>";            string tpl = "<tr><td>{0}</td><td>{1}</td><td>{2}</td></tr>";            foreach (JObject jObject in jsonObj)            {                message += String.Format(tpl, jObject["StudentID"], jObject["Name"],jObject["Hometown"]);            }            message += "</table>";            lbMsg.InnerHtml = message;        }

輸出結果:

當然,服務端除了使用LINQ to JSON來轉換json字串外,也可以使用JsonConvert的DeserializeObject方法。如下面代碼實現上面同樣的功能。

List<Student> studentList = JsonConvert.DeserializeObject<List<Student>>(inputJsonString);//注意這裡必須為List<Student>類型,因為用戶端提交的是一個數組json            foreach (Student student in studentList)            {                message += String.Format(tpl, student.StudentID, student.Name,student.Hometown);            }
回到頂部總結

在用戶端,讀寫json對象可以使用”.”操作符或”["key”]”,json字串轉換為json對象使用eval()函數。
在服務端,由.net對象轉換json字串優先使用JsonConvert對象的SerializeObject方法,定製輸出json字串使用LINQ to JSON。由json字串轉換為.net對象優先使用JsonConvert對象的DeserializeObject方法,然後也可以使用LINQ to JSON。

JSON詳解(轉)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.