参数说明:
value:js对象
replacer:替换对象,可以是一个方法、对象或数组,将value按照替换规则展示。
space:填充参数,可以是数字或字符串,将value按照参数进行格式化展示。
方法说明:将value对象转换为指定格式的json文本。
结果:
"字符串测试"
{"name":"张三","age":28,"gender":"男"}
[{"name":"张三","age":20,"gender":"男"},{"name":"李思","age":28,"gender":"女"}]
参数为function(key,value),会根据函数返回值替换value中的值。
例如替换上面对象的gender为英文大写。
结果:
{"name":"张三","age":28,"gender":"MAN"}
[{"name":"张三","age":20,"gender":"GRIL"},{"name":"李思","age":28,"gender":"GRIL"}]
参数为数组时,会遍历数组的值,以数组的值作为value的属性。如果value原本包含该属性,那么显示该属性,如果不包含则不显示。例如:
上面的name数组包含3个值,而testObj对象值包含其中的name属性和gender属性,并不存在gril属性,所以,只会显示name和gender属性。
结果:
{"name":"张三","gender":"man"}
[{"name":"张三","gender":"gril"},{"name":"李思","gender":"gril"}]
如果将参数改为一个对象数组,那么因为对象不是一个属性,key值为“”,所以会显示一个空对象:{}
如果space参数为数字n时,value对象将被格式化,并且属性会缩进n个字符。n>10时,只会缩进10个空格,n<10时,缩进n个空格,n<=0时不进行格式化。例如:
如果space为特殊字符时,按照特殊字符格式化。
例如:"\n":每行换行。"aa":每行头部添加aa字母。
(1)转换值如果有 toJSON() 方法,该方法定义什么值将被序列化。如果一个被序列化的对象拥有 toJSON 方法,那么该 toJSON 方法就会覆盖该对象默认的序列化行为:不是该对象被序列化,而是调用 toJSON 方法后的返回值会被序列化,例如:
(2)布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值
(3)undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成 null(出现在数组中时)。函数、undefined 被单独转换时,会返回 undefined,如JSON.stringify(function(){}) or JSON.stringify(undefined)。
(4) 对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误。
(5) 所有以 symbol 为属性键的属性都会被完全忽略掉,即便 replacer 参数中强制指定包含了它们。
(6) Date 日期调用了 toJSON() 将其转换为 string 字符串(Date.toISOString()),因此会被当做字符串处理。
(7) NaN 和 Infinity 格式的数值及 null 都会被当做 null。
(8) 其他类型的对象,包括 Map/Set/WeakMap/WeakSet,仅会序列化可枚举的属性。
space 参数用来控制结果字符串里面的间距。