麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

JSON資料整理

2019-11-15 02:31:40
字體:
供稿:網(wǎng)友

JSON資料整理

PS:JSON基礎(chǔ)知識整理,大神可移步

目錄

1.什么是json

2.json語法規(guī)則

3.json基礎(chǔ)結(jié)構(gòu)

4.json基礎(chǔ)示例

5.JSON和xml比較

6. .NET操作JSON

原始方式

通用方式

內(nèi)置方式

契約方式

通過序列化將.net對象轉(zhuǎn)換為JSON字符串

使用LINQ to JSON定制JSON數(shù)據(jù)

處理客戶端提交的JSON數(shù)據(jù)

1.什么是JSON

JSON(javaScript Object Notation) 是一種輕量級的數(shù)據(jù)交換格式。它基于Javascript的一個子集。 JSON采用完全獨立于語言的文本格式,但是也使用了類似于C語言家族的習(xí)慣(包括C, C++, C#, Java, JavaScript, Perl, Python等)。這些特性使JSON成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時也易于機器解析和生成。

2.JSON語法規(guī)則

JSON 語法是 JavaScript 對象表示法語法的子集。

l 數(shù)據(jù)在名稱/值對中

l 數(shù)據(jù)由逗號分隔

l 花括號保存對象

l 方括號保存數(shù)組

JSON 數(shù)據(jù)的書寫格式是:名稱/值對。

名稱/值對包括字段名稱(在雙引號中),后面寫一個冒號,然后是值:

"firstName" : "John"

這很容易理解,等價于這條 JavaScript 語句:

firstName = "John"

JSON 值可以是:

l 數(shù)字(整數(shù)或浮點數(shù))

l 字符串(在雙引號中)

l 邏輯值(true 或 false)

l 數(shù)組(在方括號中)

l 對象(在花括號中)

l null

JSON在線校驗格式化工具:bejson

3.JSON基礎(chǔ)結(jié)構(gòu)

JSON建構(gòu)有兩種結(jié)構(gòu)

JSON簡單說就是javascript中的對象和數(shù)組,所以這兩種結(jié)構(gòu)就是對象和數(shù)組兩種結(jié)構(gòu),通過這兩種結(jié)構(gòu)可以表示各種復(fù)雜的結(jié)構(gòu)。

1、對象:對象在js中表示為“{}”括起來的內(nèi)容,數(shù)據(jù)結(jié)構(gòu)為 {key:value,key:value,...}的鍵值對的結(jié)構(gòu),在面向?qū)ο蟮恼Z言中,key為對象的屬性,value為對應(yīng)的屬性值,所以很容易理解,取值方法為 對象.key 獲取屬性值,這個屬性值的類型可以是 數(shù)字、字符串、數(shù)組、對象幾種。

2、數(shù)組:數(shù)組在js中是中括號“[]”括起來的內(nèi)容,數(shù)據(jù)結(jié)構(gòu)為 ["java","javascript","vb",...],取值方式和所有語言中一樣,使用索引獲取,字段值的類型可以是 數(shù)字、字符串、數(shù)組、對象幾種。

經(jīng)過對象、數(shù)組2種結(jié)構(gòu)就可以組合成復(fù)雜的數(shù)據(jù)結(jié)構(gòu)了。

4.JSON基礎(chǔ)示例

簡單地說,JSON 可以將 JavaScript 對象中表示的一組數(shù)據(jù)轉(zhuǎn)換為字符串,然后就可以在函數(shù)之間輕松地傳遞這個字符串,或者在異步應(yīng)用程序中將字符串從 Web 客戶機傳遞給服務(wù)器端程序。這個字符串看起來有點兒古怪,但是JavaScript很容易解釋它,而且 JSON 可以表示比"名稱 / 值對"更復(fù)雜的結(jié)構(gòu)。例如,可以表示數(shù)組和復(fù)雜的對象,而不僅僅是鍵和值的簡單列表。

名稱 / 值對

按照最簡單的形式,可以用下面這樣的 JSON 表示"名稱 / 值對":

{ "firstName": "Brett" }

這個示例非常基本,而且實際上比等效的純文本"名稱 / 值對"占用更多的空間:

firstName=Brett

但是,當(dāng)將多個"名稱 / 值對"串在一起時,JSON 就會體現(xiàn)出它的價值了。首先,可以創(chuàng)建包含多個"名稱 / 值對"的 記錄,比如:

{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }

從語法方面來看,這與"名稱 / 值對"相比并沒有很大的優(yōu)勢,但是在這種情況下 JSON 更容易使用,而且可讀性更好。例如,它明確地表示以上三個值都是同一記錄的一部分;花括號使這些值有了某種聯(lián)系。

表示數(shù)組

當(dāng)需要表示一組值時,JSON 不但能夠提高可讀性,而且可以減少復(fù)雜性。例如,假設(shè)您希望表示一個人名列表。在XML中,需要許多開始標(biāo)記和結(jié)束標(biāo)記;如果使用典型的名稱 / 值對(就像在本系列前面文章中看到的那種名稱 / 值對),那么必須建立一種專有的數(shù)據(jù)格式,或者將鍵名稱修改為 person1-firstName這樣的形式。

如果使用 JSON,就只需將多個帶花括號的記錄分組在一起:

{"people": [                { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" },                { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb"},                { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" }            ]}

這不難理解。在這個示例中,只有一個名為 people的變量,值是包含三個條目的數(shù)組,每個條目是一個人的記錄,其中包含名、姓和電子郵件地址。上面的示例演示如何用括號將記錄組合成一個值。當(dāng)然,可以使用相同的語法表示多個值(每個值包含多個記錄):

{ "

這里最值得注意的是,能夠表示多個值,每個值進而包含多個值。但是還應(yīng)該注意,在不同的主條目(programmers、authors 和 musicians)之間,記錄中實際的名稱 / 值對可以不一樣。JSON 是完全動態(tài)的,允許在 JSON 結(jié)構(gòu)的中間改變表示數(shù)據(jù)的方式。

在處理 JSON 格式的數(shù)據(jù)時,沒有需要遵守的預(yù)定義的約束。所以,在同樣的數(shù)據(jù)結(jié)構(gòu)中,可以改變表示數(shù)據(jù)的方式,甚至可以以不同方式表示同一事物。

5.JSON和XML比較

可讀性

JSON和XML的可讀性可謂不相上下,一邊是簡易的語法,一邊是規(guī)范的標(biāo)簽形式,很難分出勝負。

可擴展性

XML天生有很好的擴展性,JSON當(dāng)然也有,沒有什么是XML能擴展,而JSON卻不能擴展的。不過JSON在Javascript主場作戰(zhàn),可以存儲Javascript復(fù)合對象,有著xml不可比擬的優(yōu)勢。

編碼難度、解碼難度(略)

實例比較

XML和JSON都使用結(jié)構(gòu)化方法來標(biāo)記數(shù)據(jù),下面來做一個簡單的比較。

用XML表示中國部分省市數(shù)據(jù)如下:

<?xml version="1.0" encoding="utf-8"?><country>    <name>中國</name>    <province>        <name>黑龍江</name>        <cities>            <city>哈爾濱</city>            <city>大慶</city>        </cities>    </province>    <province>        <name>廣東</name>        <cities>            <city>廣州</city>            <city>深圳</city>            <city>珠海</city>        </cities>    </province>    <province>        <name>臺灣</name>        <cities>            <city>臺北</city>            <city>高雄</city>        </cities>    </province>    <province>        <name>新疆</name>        <cities>            <city>烏魯木齊</city>        </cities>    </province></country>

用JSON表示如下:

{    "name":"中國",    "province":[    {       "name":"黑龍江",        "cities":{            "city":["哈爾濱","大慶"]        }     },     {        "name":"廣東",        "cities":{            "city":["廣州","深圳","珠海"]        }    },    {        "name":"臺灣",        "cities":{            "city":["臺北","高雄"]        }    },    {        "name":"新疆",        "cities":{            "city":["烏魯木齊"]        }    }]}

6. .NET操作JSON

JSON文件讀入到內(nèi)存中就是字符串,.NET操作JSON就是生成與解析JSON字符串。操作JSON通常有以下幾種方式:

1. 原始方式:自己按照JSON的語法格式,寫代碼直接操作JSON字符串。如非必要,應(yīng)該很少人會走這條路,從頭再來的。

2. 通用方式:這種方式是使用開源的類庫Newtonsoft.Json(下載地址http://json.codeplex.com/)。下載后加入工程就能用。通常可以使用JObject, JsonReader, JsonWriter處理。這種方式最通用,也最靈活,可以隨時修改不爽的地方。

(1)使用JsonReader讀Json字符串:

string jsonText = @"{""input"" : ""value"", ""output"" : ""result""}";JsonReader reader = new JsonTextReader(new StringReader(jsonText));while (reader.Read()){    Console.WriteLine(reader.TokenType + "/t/t" + reader.ValueType + "/t/t" + reader.Value);}

(2)使用JsonWriter寫字符串:

StringWriter sw = new StringWriter();JsonWriter writer = new JsonTextWriter(sw);writer.WriteStartObject();writer.WritePropertyName("input");writer.WriteValue("value");writer.WritePropertyName("output");writer.WriteValue("result");writer.WriteEndObject();writer.Flush();string jsonText = sw.GetStringBuilder().ToString();Console.WriteLine(jsonText);

(3)使用JObject讀寫字符串:

JObject jo = JObject.Parse(jsonText);string[] values = jo.Properties().Select(item => item.Value.ToString()).ToArray();

(4)使用JsonSerializer讀寫對象(基于JsonWriter與JsonReader):

Project p = new Project() { Input = "stone", Output = "gold" };JsonSerializer serializer = new JsonSerializer();StringWriter sw = new StringWriter();serializer.Serialize(new JsonTextWriter(sw), p);Console.WriteLine(sw.GetStringBuilder().ToString());StringReader sr = new StringReader(@"{""Input"":""stone"", ""Output"":""gold""}");Project p1 = (Project)serializer.Deserialize(new JsonTextReader(sr), typeof(Project));Console.WriteLine(p1.Input + "=>" + p1.Output);

上面的代碼都是基于下面這個Project類定義:

class Project{    public string Input { get; set; }    public string Output { get; set; }}

此外,如果上面的JsonTextReader等類編譯不過的話,說明是我們自己修改過的類,換成你們自己的相關(guān)類就可以了,不影響使用。

3. 內(nèi)置方式:使用.NET Framework 3.5/4.0中提供的System.Web.Script.Serialization命名空間下的JavaScriptSerializer類進行對象的序列化與反序列化,很直接。

 Project p = new Project() { Input = "stone", Output = "gold" }; JavaScriptSerializer serializer = new JavaScriptSerializer(); var json = serializer.Serialize(p); Console.WriteLine(json); var p1 = serializer.Deserialize<Project>(json); Console.WriteLine(p1.Input + "=>" + p1.Output); Console.WriteLine(ReferenceEquals(p,p1))
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久超| 综合99| 日本不卡一区二区在线观看 | 日本黄色免费观看视频 | 日本高清无遮挡 | 视频一区二区在线观看 | 911色_911色sss主站色播 | 黄色网址在线视频 | 黄网站色成年大片免费高 | 中文字幕线观看 | 国产91精品久久久久久久 | 免费观看高清视频网站 | 2021国产精品视频 | 一级裸体视频 | 久久久麻豆 | 免费国产自久久久久三四区久久 | 国产精品久久久久久久久久久久午夜 | 欧美成人黄色小视频 | 久久精品亚洲精品国产欧美kt∨ | 精品午夜影院 | 毛片在线免费观看完整版 | av性色全交蜜桃成熟时 | 中午字幕无线码一区2020 | 黄色一级片免费在线观看 | 久久艹精品视频 | 成人在线视频精品 | 97超碰资源站 | 免费日韩片 | 欧美黑人xx | 久久久久亚洲国产精品 | 在线看一级片 | 成年人黄视频 | 久久精品中文 | 天天草天天干天天 | 高清国产在线 | 亚洲成人第一页 | 久久精品a一级国产免视看成人 | 麻豆视频在线播放 | 视频一区二区不卡 | 国产亚洲精品综合一区91555 | av电影网在线观看 |