JSON
JSON 格式是一種用于數(shù)據(jù)交換的文本格式
JSON對值的類型和格式有嚴(yán)格的規(guī)定:
- 復(fù)合類型的值只能是數(shù)組或?qū)ο笫洞啵荒苁呛瘮?shù),正則表達(dá)式對象、日期對象
- 簡單類型的值只有四種:字符串灼捂、數(shù)值(必須以十進(jìn)制表示)离例、布爾值和null(不能使用NaN,Infinity纵东, -Infinity和undedifined)粘招。
- 字符串必須使用雙引號表示,不能用單引號
- 對象的鍵名必須放在雙引號里
- 數(shù)組或?qū)ο笞詈笠粋€成員的后面不能加逗號
以下是合格的JSON格式
["one", "two", "three"]
{ "one": 1, "two": 2, "three": 3 }
{"names": ["張三", "李四"] }
[ { "name": "張三"}, {"name": "李四"} ]
以下是不合格的 JSON 格式
{ name: "張三", 'age': 32 } // 屬性名必須使用雙引號
[32, 64, 128, 0xFFF] // 不能使用十六進(jìn)制值
{ "name": "張三", "age": undefined } // 不能使用undefined
{ "name": "張三",
"birthday": new Date('Fri, 26 Aug 2011 07:13:10 GMT'),
"getName": function() {
return this.name;
}
} // 不能使用函數(shù)和日期對象
JSON.parse()
JSON.parse方法用于將JSON字符串轉(zhuǎn)化成對象偎球。
JSON.parse('{}') // {}
JSON.parse('true') // true
JSON.parse('"foo"') // "foo"
JSON.parse('[1, 5, "false"]') // [1, 5, "false"]
JSON.parse('null') // null
var o = JSON.parse('{"name": "張三"}');
o.name // 張三
JSON.stringify()
JSON.stringify方法用于將一個值轉(zhuǎn)為字符串洒扎。該字符串符合 JSON 格式,并且可以被JSON.parse方法還原
JSON.stringify('abc') // ""abc""
JSON.stringify(1) // "1"
JSON.stringify(false) // "false"
JSON.stringify([]) // "[]"
JSON.stringify({}) // "{}"
JSON.stringify([1, "false", false])
// '[1,"false",false]'
JSON.stringify({ name: "張三" })
// '{"name":"張三"}'