JSON 数据格式程序员
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。JSON采用彻底独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。
基础结构
JSON建构于两种结构:web
基础示例
简单地说,JSON 能够将 JavaScript 对象中表示的一组数据转换为字符串,而后就能够在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序。这个字符串看起来有点儿古怪,可是 JavaScript 很容易解释它,并且 JSON 能够表示比"名称 / 值对"更复杂的结构。例如,能够表示数组和复杂的对象,而不只仅是键和值的简单列表。
表示名称 / 值对
按照最简单的形式,能够用下面这样的 JSON 表示 "名称 / 值对" :{ "firstName": "Brett" }json
这个示例很是基本,并且实际上比等效的纯文本 "名称 / 值对" 占用更多的空间:firstName=Brett数组
可是,当将多个"名称 / 值对"串在一块儿时,JSON 就会体现出它的价值了。首先,能够建立包含多个"名称 / 值对"的 记录,好比:服务器
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }
从语法方面来看,这与"名称 / 值对"相比并无很大的优点,可是在这种状况下 JSON 更容易使用,并且可读性更好。例如,它明确地表示以上三个值都是同一记录的一部分;花括号使这些值有了某种联系。
表示数组
当须要表示一组值时,JSON 不但可以提升可读性,并且能够减小复杂性。例如,假设您但愿表示一我的名列表。在 XML 中,须要许多开始标记和结束标记;若是使用典型的 名称 / 值 对(就像在本系列前面文章中看到的那种名称 / 值对),那么必须创建一种专有的数据格式,或者将键名称修改成 person1-firstName这样的形式。网络
若是使用 JSON,就只需将多个带花括号的记录分组在一块儿:数据结构
{ "people": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }, { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb"}, { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" } ]}
这不难理解。在这个示例中,只有一个名为 people的变量,值是包含三个条目的数组,每一个条目是一我的的记录,其中包含名、姓和电子邮件地址。上面的示例演示如何用括号将记录组合成一个值。固然,可使用相同的语法表示多个值(每一个值包含多个记录):异步
{ "programmers": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }, { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb" }, { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" } ], "authors": [ { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" }, { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" }, { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" } ], "musicians": [ { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" }, { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" } ] }
这里最值得注意的是,可以表示多个值,每一个值进而包含多个值。可是还应该注意,在不一样的主条目(programmers、authors 和 musicians)之间,记录中实际的名称 / 值对能够不同。JSON 是彻底动态的,容许在 JSON 结构的中间改变表示数据的方式。编辑器
在处理 JSON 格式的数据时,没有须要遵照的预约义的约束。因此,在一样的数据结构中,能够改变表示数据的方式,甚至能够以不一样方式表示同一事物。 函数
格式应用
掌握了 JSON 格式以后,在 JavaScript 中使用它就很简单了。JSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不须要任何特殊的 API 或工具包。
将 JSON 数据赋值给变量
例如,能够建立一个新的 JavaScript 变量,而后将 JSON 格式的数据字符串直接赋值给它:
var people = { "programmers": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }, { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb" }, { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" } ], "authors": [ { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" }, { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" }, { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" } ], "musicians": [ { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" }, { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" } ] }
这很是简单;如今 people包含前面看到的 JSON 格式的数据。可是,这还不够,由于访问数据的方式彷佛还不明显。
访问数据
尽管看起来不明显,可是上面的长字符串实际上只是一个数组;将这个数组放进 JavaScript 变量以后,就能够很轻松地访问它。实际上,只需用点号表示法来表示数组元素。因此,要想访问 programmers 列表的第一个条目的姓氏,只需在 JavaScript 中使用下面这样的代码:
people.programmers[0].lastName;
注意,数组索引是从零开始的。因此,这行代码首先访问 people变量中的数据;而后移动到称为 programmers的条目,再移动到第一个记录([0]);最后,访问 lastName键的值。结果是字符串值 “McLaughlin”。
下面是使用同一变量的几个示例。
people.authors[1].genre // Value is "fantasy" people.musicians[3].lastName // Undefined. This refers to the fourth entry, and there isn't one people.programmers[2].firstName // Value is "Elliotte"
利用这样的语法,能够处理任何 JSON 格式的数据,而不须要使用任何额外的 JavaScript 工具包或 API。
修改 JSON 数据
正如能够用点号和括号访问数据,也能够按照一样的方式轻松地修改数据:
people.musicians[1].lastName = "Rachmaninov";
在将字符串转换为 JavaScript 对象以后,就能够像这样修改变量中的数据。
转换回字符串
固然,若是不能轻松地将对象转换回本文提到的文本格式,那么全部数据修改都没有太大的价值。在 JavaScript 中这种转换也很简单:
String newJSONtext = people.toJSONString();
这样就好了!如今就得到了一个能够在任何地方使用的文本字符串,例如,能够将它用做 Ajax 应用程序中的请求字符串。
更重要的是,能够将任何JavaScript 对象转换为 JSON 文本。并不是只能处理原来用 JSON 字符串赋值的变量。为了对名为 myObject的对象进行转换,只需执行相同形式的命令:
String myObjectInJSON = myObject.toJSONString();
这就是 JSON 与本系列讨论的其余数据格式之间最大的差别。若是使用 JSON,只需调用一个简单的函数,就能够得到通过格式化的数据,能够直接使用了。对于其余数据格式,须要在原始数据和格式化数据之间进行转换。即便使用 Document Object Model 这样的 API(提供了将本身的数据结构转换为文本的函数),也须要学习这个 API 并使用 API 的对象,而不是使用原生的 JavaScript 对象和语法。
最终结论是,若是要处理大量 JavaScript 对象,那么 JSON 几乎确定是一个好选择,这样就能够轻松地将数据转换为能够在请求中发送给服务器端程序的格式。
概念比较
JSON和XML的比较
◆可读性
JSON和XML的可读性可谓不相上下,一边是简易的语法,一边是规范的标签形式,很难分出胜负。
◆可扩展性
XML天生有很好的扩展性,JSON固然也有,没有什么是XML能扩展,而JSON却不能。不过JSON在Javascript主场做战,能够存储Javascript复合对象,有着xml不可比拟的优点。
◆编码难度
XML有丰富的编码工具,好比Dom4j、JDom等,JSON也有提供的工具。无工具的状况下,相信熟练的开发人员同样能很快的写出想要的xml文档和JSON字符串,不过,xml文档要多不少结构上的字符。
◆解码难度
XML的解析方式有两种:
一是经过文档模型解析,也就是经过父标签索引出一组标记。例如:xmlData.getElementsByTagName("tagName"),可是这样是要在预先知道文档结构的状况下使用,没法进行通用的封装。
另一种方法是遍历节点(document 以及 childNodes)。这个能够经过递归来实现,不过解析出来的数据仍旧是形式各异,每每也不能知足预先的要求。
凡是这样可扩展的结构数据解析起来必定都很困难。
JSON也一样如此。若是预先知道JSON结构的状况下,使用JSON进行数据传递简直是太美妙了,能够写出很实用美观可读性强的代码。若是你是纯粹的前台开发人员,必定会很是喜欢JSON。可是若是你是一个应用开发人员,就不是那么喜欢了,毕竟xml才是真正的结构化标记语言,用于进行数据传递。
而若是不知道JSON的结构而去解析JSON的话,那简直是噩梦。费时费力不说,代码也会变得冗余拖沓,获得的结果也不尽人意。可是这样也不影响众多前台开发人员选择JSON。由于json.js中的toJSONString()就能够看到JSON的字符串结构。固然不是使用这个字符串,这样仍旧是噩梦。经常使用JSON的人看到这个字符串以后,就对JSON的结构很明了了,就更容易的操做JSON。
以上是在Javascript中仅对于数据传递的xml与JSON的解析。在Javascript地盘内,JSON毕竟是主场做战,其优点固然要远远优越于xml。若是JSON中存储Javascript复合对象,并且不知道其结构的话,我相信不少程序员也同样是哭着解析JSON的。
◆实例比较
XML和JSON都使用结构化方法来标记数据,下面来作一个简单的比较。
用XML表示中国部分省市数据以下:
<?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> </country>
用JSON表示以下:
{ {name:"中国", province:[ { name:"黑龙江", cities:{ city:["哈尔滨","大庆"] }, {name:"广东", cities:{ city:["广州","深圳","珠海"] } }
编码的可读性,xml有明显的优点,毕竟人类的语言更贴近这样的说明结构。json读起来更像一个数据块,读起来就比较费解了。不过,咱们读起来费解的语言,偏偏是适合机器阅读,因此经过json的索引.province[0].name就可以读取“黑龙江”这个值。
编码的手写难度来讲,xml仍是舒服一些,好读固然就好写。不过写出来的字符JSON就明显少不少。去掉空白制表以及换行的话,JSON就是密密麻麻的有用数据,而xml却包含不少重复的标记字符。
JSON在线校验工具
前言
JSON格式取代了xml给网络传输带来了很大的便利,可是却没有了xml的一目了然,尤为是json数据很长的时候,咱们会陷入繁琐复杂的数据节点查找中。
可是国人的一款在线工具 BeJson 给众多程序员带来了一阵凉风。
功能简介
不少人在获得JSON数据后,一时没有办法判断JSON数据格式是否正确,是否少或多符号而致使程序不能解析,这个功能正好能帮助你们来完成JSON格式的校验。
想必不少程序员都会遇到当找一个节点的时候,会发现若是直接对着一行行数据无从下手,就算知道哪一个位置,还要一个节点一个节点的往下找,万一一不留神又得从头开始找的麻烦事。
有了这个功能,一切JSON数据都会变成视图格式,一目了然,什么对象下有多少数组,一个数组下有多少对象。
这个功能很是实用。不光有视图功能还有格式化、压缩、转义、校验功能。总之很强大。
程序员在写JSON语句测试用例的时候,不少时候为了方便直接写了个JSON字符串作测试,可是又陷入了无止境的双引号转义的麻烦中。这款功能集压缩、转义于一身,让你在写测试用例的时候,如鱼得水。
若是你如今的电脑刚巧没有装你所熟悉的编辑器,若是你想针对拿到的JSON数据的某个节点作数据修改时,这个功能能够知足你的需求。
你们都知道,JSON用的最多的仍是web项目的开发,那你要测试一个接口是否能准确的接受JSON数据,那你就得写一个页面发送JSON字符串,重复的作着这件事。随着这个功能的横空出世,你能够摆脱写测试页面了,由于这个功能能够将指定的JSON数据发送指定的url,方便吧。
不少人在写文档时,总但愿文档能一目了然,可是面对着白底黑字的JSON数据老是提不起精神不要紧,使用这个功能,全部的关键字都会被着色,数据结构一目了然。
顾名思义,将JSON格式的数据转化成XML格式、或者XML格式的数据转化成JSON格式,一切都不是问题。