其他分享
首页 > 其他分享> > JSON.stringify使用时不安全的JSON值

JSON.stringify使用时不安全的JSON值

作者:互联网

JSON.stringify使用时不安全的JSON值

前提:

安全的JSON值是指能够呈现为有效JSON格式的值。所有安全的JSON值都能够使用JSON.stringify()字符串化

正文:

不安全的JSON值有:undefined、function、symbol和包含循环引用(对象之间相互引用,形成一个无限循环)的对象。

JSON.stringify()遇到这些JSON值时会进行以下处理:
1)对象:遇到 undefined、function 和 symbol 时会自动将该属性忽略,对包含循环引用的对象执行 JSON.stringify(…) 会出错。
2)数组:会返回 null(以保证单元位置不变)

解决方法: 在对象中定义能返回安全JSON值的toJSON方法,返回一个能够被字符串化的安全的 JSON 值,例如

var a = {
 val: [1,2,3],
 toJSON: function(){
 	return this.val.slice( 1 );
 }
};

标签:function,stringify,对象,安全,JSON,toJSON
来源: https://blog.csdn.net/qq_36347105/article/details/105267993