JSON.stringify()、JSON.parse()、Object.toJSON()

什么是JSON

    JSON(javascript object nanotion,js对象标记)是轻量级的数据交换格式,采用独立于语言的文本格式来存储和表示数据。JSON采用键值对保存数据,数据使用逗号分隔,花括号保存对象,方括号保存数组,键名使用双引号,键值间使用冒号分隔。如:

{
"name":[{"cnt":"张三","country":"中国"},{"cnt":"san zhang","country":"usa"}],
"ah":["游泳","唱歌","看电视"],
"age":18,
"addr":"北京路123号"
}

JSON与JS对象的区别

JSON是JS对象的字符串表示法,JSON的本质是字符串。

JS对象转JSON

JSON.stringify(obj[,replacer[,space]]);

第一个参数

var obj = { name: '韩梅梅', sex: 'woman', phone: '12345678', address: '北京市' };
var str = JSON.stringify(obj);
console.log(str);
//{"name":"韩梅梅","sex":"woman","phone":"12345678","address":"北京市"}

第二个参数

第二个参数有两种形式,函数和数组。

如果是函数,那么序列化过程中的每个属性都会被这个函数转化和处理,不需要被处理的,需要直接返回。

var str = JSON.stringify(obj, function(k, v) {
    if (k == "phone")
       return '(010)' + v;
else if (k == "address")
       return v + "人民教育出版社";
    else
        return v; //如果没有该句,返回整个json返回undefined
    });
console.log(str);
//{"name":"韩梅梅","sex":"woman","phone":"(010)12345678","address":"北京市人民教育出版社"}

如果是数组,只有包含在这个数组中的属性才会被序列化到最终的json字符串中。类似刷选的作用,只有既在对象中,又在数组中的属性才会写进json中。

var str = JSON.stringify(obj, ["name", "phone", "lg"]);
console.log(str); //{"name":"韩梅梅","phone":"12345678"}

第三个参数

    Space用于美化输出,不建议使用。可以填写1-10的数字,用于填充n个空白字符串;也可以填写字符串,用该字符串填写空白,最多取字符串的前10个字符。

var str = JSON.stringify(obj, null, 5);
console.log(str);
// {
//     "name": "韩梅梅",
//     "sex": "woman",
//     "phone": "12345678",
//     "address": "北京市"
//}
var str = JSON.stringify(obj, null, "HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH");
console.log(str);
//{
//HHHHHHHHHH"name": "韩梅梅",
//HHHHHHHHHH"sex": "woman",
//HHHHHHHHHH"phone": "12345678",
//HHHHHHHHHH"address": "北京市"
//}

JSON转JS对象

JOSN.parse(str[,reviver]);

第一个参数

var str = '{"name":"韩梅梅","sex":"woman","phone":"12345678","address":"北京市"}';
var obj = JSON.parse(str);
console.log(obj.name); //韩梅梅

第二个参数

该参数必须是函数,该函数的作用在属性已经被解析,但还没有返回前,将属性处理后,再返回。

var obj = JSON.parse(str, function(k, v) {
   if (k == "phone")
      return "123*****";
   else return v; //如果没有词句,会返回错误
});
console.log(obj.name + "-" + obj.phone); //韩梅梅-123****

Object.toJSON函数

如果在一个对象上实现了toJSON方法,那么调用JSON.stringify序列化这个对象时,会把这个toJSON方法返回的值作为这个对象的json字符串。

var obj = { name: '韩梅梅', sex: 'woman', phone: '12345678', address: '北京市',
            "toJSON": function() { return this.name+"-"+this.sex; }};
var str = JSON.stringify(obj);
console.log(str); //"韩梅梅-woman "
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值