一、
1、
JSON.stringify(obj) 将 JSON 转为字符串:
var a={"name":"tom","sex":"男","age":"24"};
var aToStr = JSON.stringify(a);
alert(aToStr); //结果:{"name":"tom","sex":"男","age":"24"}
结果:string
2、
JSON.parse(string) 将字符串转为 JSON 格式
var b='{"name":"tom","sex":"男","age":"24"}';
var aToObj = JSON.parse(b);
console.log(aToObj); //结果:Object {name: "tom", sex: "男", age: "24"}
二、JSON
1、JSON字符串必须使用双引号(单引号会导致语法错误)。
2、JSON 不支持 JavaScript 中的特殊值 undefined。
3、JSON 对象的属性必须加双引号。
4、JSON 中没有变量和分号。
{
"name" : "战侠歌",
"age" : 29,
"school" : {
"name" : "",
"location" : ""
}
}
以上代码虽然有两个 name 属性,但由于他们分别属于不同的对象,因此完全没有问题。
5、数组
var values = [25,"hi",true];
[
{
"title" : "JS",
"authors" : [
"authors"
],
edition : 3,
year : 2011
},
{
"title" : "JS",
"authors" : [
"authors"
],
edition : 3,
year : 2011
},
]
5、JSON 对象
** stringify() : 把 JS 对象序列化为 JSON 字符串
parse() : 把 JSON 字符串解析为原生 JS 值。**
var book = {
title : "Professional JavaScript",
authors: [
"Nicholas C. Zakas"
],
edition : 3,
year : 2001
};
var jsonText = JSON.stringify(book);
把该 JS 对象序列化为一个 JSON 字符串,然后将它保存在变量 jsonText 中。
默认情况下,JSON.stringify(); 输出的 JSON 字符串不包含任何空格字符或缩进,
因此保存在 jsonText 中的字串显示为 :
{"title":"Professional JavaScript","authors":["Nicholas C. Zakas"],"edition" : 3,"year" : 2001}
注:
在序列化 JavaScript 对象中,所有函数及原型成员都会被有意忽略,不体现在结果中。
此外,值为 undefiend 的任何属性也都会被跳过。结果中最终都是值为有效 JSON 数据类型的实例属性。
var bookCopy = JSON.parse(jsonText);
此时,book 与 bookCopy 是两个独立的、没有任何关系的对象。
如果传给 JSON.parse() 的字符串不是有效的 JSON ,该方法会抛出错误。
6、序列化选项
JSON.stringify() 除了要序列化的 JS 对象外,还接收另外两个参数。
第一个 param : 过滤器
第二个 param : 是否保留缩进。
a、过滤结果
如果过滤器参数是数组,那么 JSON.stringify() 的结果中将只包含数组中列出的属性。
var book = {
title : "Professional JavaScript",
authors: [
"Nicholas C. Zakas"
],
edition : 3,
year : 2001
};
var jsonText = JSON.stringify(book, ["title","edition"]);
返还的结果字符串
{"title":"Professional JavaScript","edition":3}
b、函数
var jsonText = JSON.stringify(book,function(key,value){
switch(key){
case "authors":
return value.join(",") //如果键为"authors",就将数组连接为一个字符串;
case "year":
return 5000; //如果键为"year",就将其值设为5000;
case "edition": //如果键为"edition",通过返回undefined删除该属性;
return undefined;
default:
return value;
}
});
注:
如果函数返回了一个 undefined,那么相应的属性会被忽略。