我已经在维基百科和谷歌上搜索了它,并阅读了官方文档,但我仍然没有真正理解JSON是什么,以及我为什么要使用它。
我已经使用PHP、MySQL和JavaScript / HTML构建了一段时间的应用程序,如果JSON可以让我的生活更轻松,或者让我的代码更好,或者让我的用户界面更好,那么我想知道它。谁能给我一个简洁的解释?
我已经在维基百科和谷歌上搜索了它,并阅读了官方文档,但我仍然没有真正理解JSON是什么,以及我为什么要使用它。
我已经使用PHP、MySQL和JavaScript / HTML构建了一段时间的应用程序,如果JSON可以让我的生活更轻松,或者让我的代码更好,或者让我的用户界面更好,那么我想知道它。谁能给我一个简洁的解释?
当前回答
JSON和传统语法的区别如下(Javascript)
传统的
function Employee(name, Id, Phone, email){
this.name = name;
this.Id = Id;
this.Phone = Phone;
this.email = email;
}
//access or call it as
var Emp = new Employee("mike","123","9373849784","mike.Anderson@office.com");
用JSON
如果我们使用JSON,我们可以用不同的方式定义
function Employee(args){
this.name = args.name;
this.Id = args.Id;
this.Phone = args.Phone;
this.email = args.email;
}
//now access this as...
var Emp = new Employee({'name':'Mike', 'Id':'123', 'Phone':'23792747', 'email':'mike.adnersone@office.com'});
我们必须记住的重要事情是,如果我们必须用100个元素构建“Employee”类或模态,而不使用JSON方法,我们必须在创建类时解析所有内容。但是使用JSON,我们只能在定义类的新对象时内联定义对象。
下面这一行是JSON的处理方式(只是一种简单的定义方式)
var Emp = new Employee({'name':'Mike', 'Id':'123', 'Phone':'23792747', 'email':'mike.adnersone@office.com'});
其他回答
JSON(Javascript对象表示法)是一种用于数据交换/传输的轻量级数据格式。它和JavaScript一样是键值对。 REST API广泛用于从服务器到客户端的数据传输。如今,许多社交媒体网站都在使用这种方式。尽管就数据类型而言,我认为它不如XML健壮。XML有非常丰富的数据类型和XSD。JSON在这方面有点欠缺。
对于相同数量的字符串数据,JSON将比XML更轻,因为XML有所有的开始和结束标签,等等…
我喜欢JSON主要是因为它非常简洁。对于可以被gzip压缩的web内容来说,这并不是什么大问题(这就是xhtml如此流行的原因)。但在某些情况下,这是有益的。
例如,在一个项目中,我正在传输需要序列化并通过XMPP传输的信息。由于大多数服务器都会限制您在单个消息中传输的数据量,因此我发现使用JSON比使用XML更有帮助。
作为一个额外的好处,如果你熟悉Python或Javascript,你已经非常了解JSON,并且不需要太多训练就可以解释它。
JSON (JavaScript对象表示法)是一种用于数据交换的轻量级格式。它基于JavaScript语言的一个子集(在JavaScript中构建对象的方式)。正如MDN中所述,有些JavaScript不是JSON,有些JSON也不是JavaScript。
使用这种方法的一个例子是web服务响应。在过去,web服务使用XML作为传输回数据的主要数据格式,但自从JSON出现以来(JSON格式由Douglas Crockford在RFC 4627中指定),它已经成为首选格式,因为它更轻量级
您可以在官方JSON网站上找到更多信息。
JSON构建在两个结构上:
名称/值对的集合。在各种语言中,这可以实现为对象、记录、结构、字典、散列表、键控列表或关联数组。 一个有序的值列表。在大多数语言中,这是通过数组、向量、列表或序列来实现的。
JSON结构
下面是一个JSON数据的例子:
{
"firstName": "John",
"lastName": "Smith",
"address": {
"streetAddress": "21 2nd Street",
"city": "New York",
"state": "NY",
"postalCode": 10021
},
"phoneNumbers": [
"212 555-1234",
"646 555-4567"
]
}
JavaScript JSON
JSON(在Javascript中)是一个字符串!
人们通常认为所有Javascript对象都是JSON,并且JSON是Javascript对象。这是不正确的。
在Javascript中var x = {x:y}不是JSON,这是一个Javascript对象。这两者不是一回事。JSON的等效值(用Javascript语言表示)是var x = '{"x":"y"}'。X是一个字符串类型的对象,而不是它本身的对象。要把它变成一个完全成熟的Javascript对象,你必须首先解析它,var x = JSON.parse('{"x":"y"}');, x现在是一个对象,但这不再是JSON。
参见Javascript对象Vs JSON
当使用JSON和JavaScript时,你可能会尝试使用eval函数来计算回调返回的结果,但不建议这样做,因为在JSON中有两个字符(U+2028和U+2029)有效,而在JavaScript中无效(在这里阅读更多)。
因此,在计算JSON之前,必须总是尝试使用Crockford的脚本来检查有效的JSON。在这里可以找到脚本解释的链接,这里是到js文件的直接链接。现在每个主流浏览器都有自己的实现。
关于如何使用JSON解析器的例子(使用上面代码片段中的JSON):
//The callback function that will be executed once data is received from the server
var callback = function (result) {
var johnny = JSON.parse(result);
//Now, the variable 'johnny' is an object that contains all of the properties
//from the above code snippet (the json example)
alert(johnny.firstName + ' ' + johnny.lastName); //Will alert 'John Smith'
};
JSON解析器还提供了另一种非常有用的方法stringify。该方法接受一个JavaScript对象作为参数,并输出一个JSON格式的字符串。当你想将数据发送回服务器时,这很有用:
var anObject = {name: "Andreas", surname : "Grech", age : 20};
var jsonFormat = JSON.stringify(anObject);
//The above method will output this: {"name":"Andreas","surname":"Grech","age":20}
上面的两个方法(parse和stringify)还带有第二个参数,这是一个函数,将在最终结果的每个级别上为每个键和值调用,每个值将被输入函数的结果替换。(更多信息请点击这里)
顺便说一句,对于那些认为JSON只是用于JavaScript的人来说,看看这篇文章,它解释并证实了这一点。
参考文献
JSON.org 维基百科 Json在3分钟内(谢谢mson) 在Yahoo!Web服务(感谢gljivar) JSON到CSV转换器 替代JSON到CSV转换器 JSON Lint (JSON验证器)
JSON是JavaScript对象表示法。与XML相比,它是一种更紧凑的跨网络连接传输数据集的方式。 我建议在任何类似ajax的应用程序中使用JSON,否则XML将是“推荐的”选项。XML的冗长会增加下载时间和带宽消耗($$$)。您可以使用JSON实现同样的效果,而且它的标记几乎专门用于数据本身,而不是底层结构。
在Java上下文中,使用JSON的一个原因可能是,它为Java的Serialization框架提供了一个非常好的替代方案,而Java的Serialization框架(历史上)已被证明存在一些相当严重的漏洞。
Joshua Bloch在第85项“首选Java序列化的替代方案”(Effective Java 3rd Edition)中深入讨论了这一点。
Java的序列化最初的目的是将数据结构转换为易于传输或存储的格式。JSON满足这一要求,没有上面提到的严重漏洞。