javascript
JSON——IT技术人员都必须要了解的一种数据交换格式
JSON作為目前Web主流的數(shù)據(jù)交換格式,是每個(gè)IT技術(shù)人員都必須要了解的一種數(shù)據(jù)交換格式。尤其是在Ajax和REST技術(shù)的大行其道的當(dāng)今,JSON無(wú)疑成為了數(shù)據(jù)交換格式的首選!
今天大家就和豬哥一起來(lái)學(xué)習(xí)一下JSON的相關(guān)知識(shí)吧!
一、XML
在講JSON之前,我覺得有必要先帶大家了解一下XML(Extensible Markup Language 可擴(kuò)展標(biāo)記語(yǔ)言),因?yàn)镴SON正在慢慢取代XML。
1.XML起源
早期Web發(fā)展和負(fù)載的數(shù)據(jù)量并不是很大,所以基本靠HTML(1989誕生)可以解決。但是隨著Web應(yīng)用的不斷壯大,HTML的一些缺點(diǎn)也慢慢顯現(xiàn),如:可讀性差、解析時(shí)間長(zhǎng)、數(shù)據(jù)描述性差等。
1998年2月10日,W3C(World WideⅥiebConsortium,萬(wàn)維網(wǎng)聯(lián)盟)公布XML 1.0標(biāo)準(zhǔn),XML誕生了。
XML使用一個(gè)簡(jiǎn)單而又靈活的標(biāo)準(zhǔn)格式,為基于Web的應(yīng)用提供了一個(gè)描述數(shù)據(jù)和交換數(shù)據(jù)的有效手段。但是,XML并非是用來(lái)取代HTML的。HTML著重如何描述將文件顯示在瀏覽器中,它著重描述如何將數(shù)據(jù)以結(jié)構(gòu)化方式表示。
XML簡(jiǎn)單易于在任何應(yīng)用程序中讀/寫數(shù)據(jù),這使XML很快成為數(shù)據(jù)交換的唯一公共語(yǔ)言,所以XML被廣泛應(yīng)用。
注意: XML是一種數(shù)據(jù)交換的格式,并不是編程語(yǔ)言。而且他是跨語(yǔ)言的數(shù)據(jù)格式,目前絕大多數(shù)編程語(yǔ)言均支持XML。
2.XML實(shí)例
XML究竟怎么用?是什么樣子的?我們來(lái)舉一個(gè)簡(jiǎn)單的例子吧!
A公司要和B公司業(yè)務(wù)對(duì)接(A公司要獲取B公司的用戶基本信息),B公司提供接口讓A公司調(diào)用,A、B公司對(duì)接的開發(fā)人員會(huì)提前溝通好這個(gè)接口的:URL、傳參、返回?cái)?shù)據(jù)、異常等等。
但是也許兩個(gè)公司使用的技術(shù)棧并不相同,所以支持的據(jù)格式也可能不同。為了解決因技術(shù)棧不同帶來(lái)的數(shù)據(jù)格式不同問題,A、B公司的開發(fā)協(xié)商使用一種通用的數(shù)據(jù)格式來(lái)傳輸,于是他們想到了XML。
3.XML十字路口
雖然XML標(biāo)準(zhǔn)本身簡(jiǎn)單,但與XML相關(guān)的標(biāo)準(zhǔn)卻種類繁多,W3C制定的相關(guān)標(biāo)準(zhǔn)就有二十多個(gè),采用XML制定的重要的電子商務(wù)標(biāo)準(zhǔn)就有十多個(gè)。這給軟件開發(fā)工程師帶來(lái)了極大的麻煩!
隨著AJax(之前叫XMLHTTP,2005年后才叫Ajax)技術(shù)的流行,XML的弊端也越來(lái)越顯現(xiàn):大家都知道XML實(shí)現(xiàn)是基于DOM樹實(shí)現(xiàn)的,而DOM在各種瀏覽器中的實(shí)現(xiàn)細(xì)節(jié)不盡相同,所以XML的跨瀏覽器兼容性并不好,所以急需一種新的數(shù)據(jù)負(fù)載格式集成到HTML頁(yè)面中以滿足Ajax的要求!
二、JSON
前面我們說了隨著Ajax的流行,而各種瀏覽器對(duì)DOM的實(shí)現(xiàn)細(xì)節(jié)不盡相同,所以會(huì)出現(xiàn)兼容性問題,這對(duì)前端開發(fā)同學(xué)來(lái)講真的是災(zāi)難。因?yàn)橐粋€(gè)功能可能需要用代碼去兼容各種不同的瀏覽器,還要調(diào)試,工作量巨大。
1.JSON誕生
如何才能將數(shù)據(jù)整合到HTML中又解決瀏覽器兼容性問題呢?答案就是:利用所有主流瀏覽器中的一種通用組件——JavaScript引擎。這樣只要?jiǎng)?chuàng)造一種JavaScript引擎能識(shí)別的數(shù)據(jù)格式就可以啦!
2001 年 4 月,首個(gè) JSON 格式的消息被發(fā)送出來(lái)。此消息是從舊金山灣區(qū)某車庫(kù)的一臺(tái)計(jì)算機(jī)發(fā)出的,這是計(jì)算機(jī)歷史上重要的的時(shí)刻。道格拉斯·克羅克福特(Douglas Crockford) 和 奇普·莫寧斯達(dá)(Chip Morningstar) 是一家名為 State Software 的技術(shù)咨詢公司的聯(lián)合創(chuàng)始人(后來(lái)都在雅虎任職),他們當(dāng)時(shí)聚集在 Morningstar 的車庫(kù)里測(cè)試某個(gè)想法,發(fā)出了此消息。
document.domain = 'fudco'; parent.session.receive( { to: "session", do: "test", text: "Hello world" } )熟悉js的同學(xué)是不是也很驚訝,第一個(gè) JSON 消息它明顯就是 JavaScript!實(shí)際上,Crockford 自己也說過他不是第一個(gè)這樣做的人。網(wǎng)景(Netscape )公司的某人早在 1996 年就使用 JavaScript 數(shù)組字面量來(lái)交換信息。因?yàn)橄⒕褪?JavaScript,其不需要任何特殊解析工作,JavaScript 解釋器就可搞定一切。
最初的 JSON 信息實(shí)際上與 JavaScript 解釋器發(fā)生了沖突。JavaScript 保留了大量的關(guān)鍵字(ECMAScript 6 版本就有 64 個(gè)保留字),Crockford 和 Morningstar 無(wú)意中在其 JSON 中使用了一個(gè)保留字:do。因?yàn)?JavaScript 使用的保留字太多了,所以Crockford決定:既然不可避免的要使用到這些保留字,那就要求所有的 JSON 鍵名都加上引號(hào)。被引起來(lái)的鍵名會(huì)被 JavaScript 解釋器識(shí)別成字符串。這就為什么今天 JSON 鍵名都要用引號(hào)引起來(lái)的原因。
這種數(shù)據(jù)格式既然可以被JavaScript引擎識(shí)別,那就解決了XML帶來(lái)的各種瀏覽器兼容性問題,所以這種技術(shù)完全可以推廣出去,于是Crockford 和 Morningstar 想給其命名為 “JSML”,表示JavaScript 標(biāo)記語(yǔ)言(JavaScript Markup Language)的意思,但發(fā)現(xiàn)這個(gè)縮寫已經(jīng)被一個(gè)名為 Java Speech 標(biāo)記語(yǔ)言的東西所使用了。所以他們決定采用 “JavaScript Object Notation”,縮寫為 JSON,至此JSON正式誕生。
2.JSON發(fā)展
2005 年,JSON 有了一次大爆發(fā)。那一年,一位名叫 Jesse James Garrett 的網(wǎng)頁(yè)設(shè)計(jì)師和開發(fā)者在博客文章中創(chuàng)造了 “AJAX” 一詞。他很謹(jǐn)慎地強(qiáng)調(diào):AJAX 并不是新技術(shù),而是 “好幾種蓬勃發(fā)展的技術(shù)以某種強(qiáng)大的新方式匯集在一起?!?AJAX 是 Garrett 給這種正受到青睞的 Web 應(yīng)用程序的新開發(fā)方法的命名。他的博客文章接著描述了開發(fā)人員如何利用 JavaScript 和 XMLHttpRequest 構(gòu)建新型應(yīng)用程序,這些應(yīng)用程序比傳統(tǒng)的網(wǎng)頁(yè)更具響應(yīng)性和狀態(tài)性。他還以 Gmail 和 Flickr 網(wǎng)站已經(jīng)使用 AJAX 技術(shù)作為了例子。
當(dāng)然了,“AJAX” 中的 “X” 代表 XML。但在隨后的問答帖子中,Garrett 指出,JSON 可以完全替代 XML。他寫道:“雖然 XML 是 AJAX 客戶端進(jìn)行數(shù)據(jù)輸入、輸出的最完善的技術(shù),但要實(shí)現(xiàn)同樣的效果,也可以使用像 JavaScript Object Notation(JSON)或任何類似的結(jié)構(gòu)數(shù)據(jù)方法等技術(shù)。 ”
這時(shí)JSON便在國(guó)外的博客圈、技術(shù)圈慢慢流行起來(lái)!
2006 年,Dave Winer,一位高產(chǎn)的博主,他也是許多基于 XML 的技術(shù)(如 RSS 和 XML-RPC)背后的開發(fā)工程師,他抱怨到 JSON 毫無(wú)疑問的正在重新發(fā)明 XML。
Crockford 閱讀了 Winer 的這篇文章并留下了評(píng)論。為了回應(yīng) JSON 重新發(fā)明 XML 的指責(zé),Crockford 寫到:“重造輪子的好處是可以得到一個(gè)更好的輪子”。
3.當(dāng)今JSON地位
當(dāng)今的JSON 已經(jīng)占領(lǐng)了全世界。絕大多數(shù)的應(yīng)用程序彼此通過互聯(lián)網(wǎng)通信時(shí),都在使用 JSON。它已被所有大型企業(yè)所采用:十大最受歡迎的 web API 接口列表中(主要由 Google、Facebook 和 Twitter 提供),僅僅只有一個(gè) API 接口是以 XML 的格式開放數(shù)據(jù)的。
JSON 也在程序編碼級(jí)別和文件存儲(chǔ)上被廣泛采用:在 Stack Overflow上,關(guān)于JSON的問題越來(lái)越多,下圖是關(guān)于Stack Overflow上不同數(shù)據(jù)交換格式的問題數(shù)和時(shí)間的曲線關(guān)系圖。
從上圖我們可以看出在Stack Overflow上越來(lái)越多JSON的問題,從這里也可以反映出JSON越來(lái)越流行!
更詳細(xì)的關(guān)于創(chuàng)造JSON的故事可閱讀:https://www.jianshu.com/p/62a856367d2d
4.JSON實(shí)例
還是以上面A、B公司業(yè)務(wù)對(duì)接為例子,兩邊的開發(fā)人員協(xié)商一種通用的數(shù)據(jù)交換格式,現(xiàn)在有XML與JSON比較流行的兩種數(shù)據(jù)格式,于是開發(fā)人員又將用戶信息以JSON形式展現(xiàn)出來(lái),然后比較兩種數(shù)據(jù)格式:
{"person": {"name": "pig","age": "18","sex": "man","hometown": {"province": "江西省","city": "撫州市","county": "崇仁縣"}} }比較XML與JSON的數(shù)據(jù)格式之后,開發(fā)人員發(fā)現(xiàn):JSON可閱讀性、簡(jiǎn)易性更好而且相同數(shù)據(jù)負(fù)載JSON字符數(shù)更少,所以兩個(gè)開發(fā)人員一致同意使用JSON作為接口數(shù)據(jù)格式!
而且還有重要的一點(diǎn),在編寫XML時(shí),第一行需要定義XML的版本,而JSON不存在版本問題,格式永遠(yuǎn)不變!
三、總結(jié)
由于篇幅原因我們今天只學(xué)習(xí)了JSON的誕生和起源相關(guān)知識(shí),知道了JSON的誕生是因?yàn)閄ML無(wú)法滿足Ajax對(duì)瀏覽器兼容性問題,所以就有人想創(chuàng)造一種瀏覽器通用組件:JavaScript引擎 能識(shí)別的數(shù)據(jù)格式,這樣就可以解決瀏覽器不兼容問題,所以就從Js數(shù)據(jù)格式中提取了一個(gè)子集,取名為JSON!
我們還知道了為什么JSON鍵為什么需要用雙引號(hào)引起來(lái),是因?yàn)镴S中存在許多的關(guān)鍵字和保留關(guān)鍵字,為了避免與JS關(guān)鍵字沖突,所以Crockford就要求在所有的鍵名上加上雙引號(hào),這樣JS引擎會(huì)將其識(shí)別為字符串,就避免與JS中關(guān)鍵字沖突!
下期我們會(huì)詳細(xì)介紹JSON數(shù)據(jù)結(jié)構(gòu)、JSON序列化、JSON在Python中的使用等知識(shí)。
了解技術(shù)誕生與發(fā)展背后的故事同樣重要,因?yàn)檫@些可以作為你吹逼的資本!
參考資料:
百度百科:XML
Daniel Rubio:JSON 簡(jiǎn)介
https://www.jianshu.com/p/62a856367d2d
總結(jié)
以上是生活随笔為你收集整理的JSON——IT技术人员都必须要了解的一种数据交换格式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 学习这么美丽的事,你要不要和我一起?
- 下一篇: JSON的使用场景及注意事项介绍