Please note, this is a STATIC archive of website developer.mozilla.org from November 2016, cach3.com does not collect or store any user information, there is no "phishing" involved.

JSON (JavaScript Object Notation) 是一个数据交换格式。它非常的接近于JavaScript语法的子集,尽管它不是一个严格的子集。(详细见JavaScript参考中的JSON。)当你在写任何基于JavaScript的应用程序的时候它都是非常有用的,包括网站和浏览器拓展。举个例子,也许你会把用户信息储存成JSON格式并放到cookie中,或者你会把拓展偏好(extension preferences)储存成为JSON格式在一个字符串值(string-valued)的浏览器偏好(browser preference)中。

JSON 的值能是由数、布尔,字符串,null以及数组(按照值的顺序排列)甚至对象(string-value mappings)这些值的表示来组成的(或者其他的数组或对象)。它不能与生俱来的用来表示更复杂的数据类型,比如函数、正则表达式,日期等等。(日期 对象默认会被序列化成为一个ISO格式的包含日期的字符串,因此它们不往返行程(round-trip),这个信息不会完全丢失。)如果你需要存储这些 值,你可以在它们被序列化的时候把它们变成值,或者先把他们反序列化(deserialization),去使JSON可以表现这些后加的数据类型。

文档

JSON对象(JSON object)
JSON对象包含一些把值转换成JavaScript Object Notation (JSON)和一些转换JSON成为值的方法(methods)。
使用本地JSON(Using native JSON
这个文章覆盖了在Gecko 1.9.1被添加的ECMAScript 5遵从本地JSON对象。
JSONPath
JSONPath是使用类似XPath语法去查询JSON结构。它不是一个标准,但是它确实代表了在不需要转换或者从XML的前提下直接查询JavaScript结构。
Downloading JSON and JavaScript in extensions
A common practice found in many extensions is using XMLHttpRequest (or some other mechanism) to download JavaScript or JSON (they are different) from a remote website. Once the content has been downloaded, the extension authors proceed to use eval() to decode the string content into JavaScript objects, which is a dangerous practice and will not, in fact, pass an AMO review. This article shows how to avoid it.
JXON
JXON 代表无损的 Javascript XML Object Notation,它是一个用来定义使用xml表示JavaScript对象树的署名。
JSON.stringify方法(JSON.stringify method)
将值转化为JSON序列,可选值:如果指定了替代函数可以在序列化前对值做一些替换。也可以是一个替代数组包含那些需要字符串化的属性名。
JSON.parse method
把字符串解析成为JSON,选择性的把值转换成JSON。

查看全部...

社区

  • 查看Mozilla论坛...

工具

查看全部...

AJAX, JavaScript, XUL

通过使用JavaScript的JSON 对象使用JSON

最简单的使用JSON的办法是通过标准JavaScript中的JSON 对象来使用。使用JSON.stringify去序列化一个JSON值,以及使用JSON.parse去反序列化一个JSON值。

例子,使用JSON.stringify()方法去序列化一个JavaScript对象:

var foo = {};
foo.bar = "new property";
foo.baz = 3;

var JSONfoo = JSON.stringify(foo);

JSONfoo 现在变成了 {"bar":"new property","baz":3}. 如果你想使 JSONfoo 再变回一个 JavaScript 对象,你只需要做:

var backToJS = JSON.parse(JSONfoo);

更多的信息你可以看JSON对象文档

toJSON()方法

如果一个对象定义了一个toJSON()方法,JSON.stringify会调用这个方法来确定这个对象的JSON表示内容,例子:

x = {}; 
x.foo = "foo";  
x.toJSON = function() { return "bar"; }; 
var json1 = JSON.stringify(x); 

json1 现在的结果是 '"bar"'。

译者注(下图是我在Chrome Console下做的):

限制

你不能序列化一个含有functions的对象,JSON规定这是不被允许的。例子:

foo.qwerty = function(){alert('foobar');}; 
foo.qwerty() 
var JSONfoo = JSON.toString(foo); 

它会抛出: TypeError on line XXX: No JSON representation for this object!

通过nsIJSON使用JSON

3.5版本之前的Firefox并不原生支持JSON,所以唯一的办法是使用nsIJSON组件,从Firefox 3开始生效。使用nsIJSONencodedecode方法来编解码。这些方法对于JSON对象来说并不足够强大,他们只支持那些是对象或者是数组的值,并不支持字符串,布尔,数字或者null。(这些值仅仅会被变成数组或对象的时候才能被支持:数字5是不会被支持的,但是{ "value": 5 }可以。

因为nsIJSON对于JSON对象来说,并不足够强大,它的encodedecode方法从Firefox 7起已经被移除了。开发需要选择使用JSON对象来代替。

下面的代码是使用nsIJSON序列化一个JavaScript对象:

var Ci = Components.interfaces;
var Cc = Components.classes;

var foo = {};
foo.bar = "new property";
foo.baz = 3;

var nativeJSON = Cc["@mozilla.org/dom/json;1"].createInstance(Ci.nsIJSON);
var JSONfoo = nativeJSON.encode(foo);

现在 JSONfoo 变量变成了字符串{"bar":"new property","baz":3}。JSONfoo再变成JavsScript对象,只需要做:

var backToJS = nativeJSON.decode(JSONfoo);

其他使用JSON的方法

理论上讲,是可以用eval去使用JSON的(但仅仅是反序列化一个对象,而不是把一个对象序列化成为一个字符串)或者是使用json2.js,不是一个好办法。用eval去解析JSON是不安全的,因为eval允许比JSON更多的语法(会使代码随意的执行)。对于json2.js,它的问题是它在构造对象的时候向其中添加了一些方法,比如Object.prototype,它非常有可能按照某种不确定的方式破坏代码。你几乎永远都需要使用先前方法中的一个去用来表述JSON。

还可以看

文档标签和贡献者

 此页面的贡献者: vino24, ziyunfei, DestinyXie, archer, liminjun, Will_Chen, Laser
 最后编辑者: vino24,