JavaScript中的对象序列化介绍
投稿:junjie
这篇文章主要介绍了JavaScript中的对象序列化介绍,JavaScript中的对象序列化是通过JSON.stringify()来实现的,而反序列化则通过JSON.parse()来实现,需要的朋友可以参考下
与Java语言一样,JavaScript中可以对对象进行序列化和反序列化,藉此对对象进行保存。ECMAScript 5标准中,JavaScript中的对象序列化是通过JSON.stringify()来实现的,而反序列化则通过JSON.parse()来实现:
复制代码 代码如下:
var o = {x:1, y:29, z:42};
var s = JSON.stringify(o);
console.log(s);//{"x":1,"y":29,"z":42}
var c = JSON.parse(s);
console.log(c);//Object {x=1, y=29, z=42}
对于仅支持ECMAScript 3标准的浏览器,可以使用Douglas Crockford写的json2.js (https://github.com/douglascrockford/JSON-js)。
在对对象进行序列化过程中,NaN、Infinity和-Infinity将被序列化成”null”;Date对象将被序列化成表示相应时间的字符串(但当使用JSON.parse()反序列化时,该时间字符串将作为普通字符串存在,不会被重新构建为Date对象)。
使用JSON.stringify()序列化对象时,所序列化的property仅限于对象自身(Own)的enumerable的property。而在JSON.stringify()运行时,JavaScript会先查找需要序列化的对象中是否有toJSON()方法,如果toJSON()方法存在,则调用该方法并将其返回的结果作为序列化的目标。如果toJSON()方法不存在,则使用默认的序列化方法。
您可能感兴趣的文章:
- GSON实现Java对象的JSON序列化与反序列化的实例教程
- jQuery实现form表单元素序列化为json对象的方法
- java对象序列化与反序列化的默认格式和json格式使用示例
- 基于jQuery的一个扩展form序列化到json对象
- 详解JavaScript对象序列化
- JavaScript 序列化对象实现代码
- js解析与序列化json数据(一)json.stringify()的基本用法
- jquery序列化form表单使用ajax提交后处理返回的json数据
- js解析与序列化json数据(二)序列化探讨
- Json序列化和反序列化方法解析
- 浅析JSON序列化与反序列化
- js解析与序列化json数据(三)json的解析探讨
- JSON与js对象序列化实例详解