一、JSON.stringify语法:
JSON.stringify(value [, replacer] [, space])
value:是必选字段。就是你输入的对象,比如数组,类等。
replacer(可选参数):它又分为2种方式,一种是数组,第二种是方法。
(1)replacer为数组时,表示的是Key,只有在类中有出现过的Key的键值对(Key-Value)才会在转化的结果中出现。
replacer数组仅对输入参数是类的情况有效,如果输入参数是数组则直接忽略该参数。
(2)replacer为方法时,表示把每一个“键值对”作为参数送入函数中,然后用处理后的Value值替代原Value值输出到转化的结果中。
replacer为方法仅对输入参数是数组的情况有效,如果输入参数是类则直接忽略该参数。
space(可选参数):就是用什么来做分隔符的。
(1)如果省略的话,那么在每个键值对(”Key”:Value)就没有分隔符,否则会默认添加一个换行符 ‘\n' 加上该分隔符。
(2)如果是字符串或者是转义字符,则会在每一个键值对(”Key”:Value)添加上换行符 ‘\n'(包括第一个键值对),然后再加上该分隔符。
var person = new Object(); person.name = 'chy'; person.age = 24; person.city= ['FuZhou', 'XiaMen']; var replacerArr = [ 'name', 'city', 'unknown' ]; var space = '-*-'; JSON.stringify(person); //输出 '{"name":"city","age":24,"city":["FuZhou","XiaMen"]}' JSON.stringify(person, replacerArr); //输出 '{"name":"chy","city":["FuZhou","XiaMen"]}' JSON.stringify(person, function(key, value) { console.log("key = " + key); return value.toString().toUpperCase(); }); /* 输出 key = '"[OBJECT OBJECT]"' */
var personArr = [ 'Bob', 'Tina', 'Tom', 'bob', 'Linda' ]; var replacerArr = [ 'name', 'city', 'unknown' ]; var space = '-*-'; JSON.stringify(personArr); //输出 '["Bob","Tina","Tom","bob","Linda"]' JSON.stringify(personArr, replacerArr); //输出 '["Bob","Tina","Tom","bob","Linda"]' JSON.stringify(personArr, function(key, value) { console.log("key = " + key); return value.toString().toUpperCase(); }); /* 输出 key = '"BOB, TINA, TOM, BOB, LINDA"' */
二、JSON.parse语法:
JSON.parse(string)
待解析的字符串无论是键还是值,都必须用”双引号”括起来。注意是双引号,单引号无效。
JSON.parse('{name:"chy"}'); //输出 SyntaxError: Unexpected token n in JSON at position 1 JSON.parse("{'name':'chy'}"); //输出 SyntaxError: Unexpected token ' in JSON at position 1 JSON.parse('{"name":"bob"}'); //输出 { name: 'bob' } JSON.parse("{\"name\":\"bob\"}"); //输出 { name: 'bob' } JSON.parse('{"age":1}'); //输出 { age: 1 }
PS:这里再为大家推荐几款相关的json在线工具供大家参考: