JavaScript之对象序列化详解

一.什么是对象序列化?git

  对象序列化是指将对象的状态转换为字符串(来自我这菜鸟的理解,好像有些书上也是这么说的,浅显易懂!);github

  序列化(Serialization)是将对象的状态信息转换为能够存储或传输的形式的过程(来自“百度百科—序列化“,学术性强,略显高端);json

二.为何会有对象序列化?数组

  世间万物,都有其存在的缘由。为何会有对象序列化呢?由于程序猿们须要它。既然是对象序列化,那咱们就先从一个对象提及:函数

var obj = {x:1, y:2};

   当这句代码运行时,对象obj的内容会存储在一块内存中,而obj自己存储的只是这块内存的地址的映射而已。简单的说,对象obj就是咱们的程序在电脑通电时在内存中维护的一种东西,若是咱们程序中止了或者电脑断电了,对象obj将不复存在。那么如何把对象obj的内容保存在磁盘上呢(也就是说在没电时继续保留着)?这时就须要把对象obj序列化,也就是说把obj的内容转换成一个字符串的形式,而后再保存在磁盘上。另外,咱们又怎么经过HTTP协议把对象obj的内容发送到客户端呢?没错,仍是须要先把对象obj序列化,而后客户端根据接收到的字符串再反序列化(也就是将字符串还原为对象)解析出相应的对象。这也正是”百度百科—序列化“中描述的两个做用——存储、传输。spa

三.JavaScript中的对象序列化code

  JSON的全称是”JavaScript Object Notation“——JavaScript对象表示法。ECMAScript 5中提供了内置函数JSON.stringify()和JSON.parse()用来序列化和还原JavaScript对象。它们使用起来也很简单:对象

能够看到,exampleStr和exampleObj2中并无 y:undefined 的内容。这说明:JSON的语法是JavaScript语法的子集,它并不能表示JavaScript中的全部值,对于JSON语法不支持的属性,序列化后会将其省略。其详细规则以下:blog

①对于JavaScript中的五种原始类型,JSON语法支持数字、字符串、布尔值、null四种,不支持undefined;ip

②NaN、Infinity和-Infinity序列化的结果是null;

JSON语法不支持函数;

④除了RegExp、Error对象,JSON语法支持其余全部对象;

日期对象序列化的结果是ISO格式的字符串,但JSON.parse()依然保留它们字符串形态,并不会将其还原为日期对象;

⑥JSON.stringify()只能序列化对象的可枚举的自有属性;

从上面的例子也能够看到,在符合以上规则的状况下,还能够经过对象序列化和反序列化完成对象的深拷贝(什么是对象的深拷贝?能够去看:https://www.zhihu.com/question/23031215,邹润阳的答案)。

  以上就是JSON.stringify()和JSON.parse()的经常使用用法了,但这两个方法并不止这么简单:

四.完整版JSON.stringify()

1.简介

  序列化原始值、对象或数组

2.概要

  JSON.stringify(o[, filter][, indent])

3.参数

  o,要转换成JSON字符串的原始值、对象或数组

  filter,可选参数,一个数组或函数

  indent,可选参数,一个数值或一个字符串

4.返回

  JSON格式的字符串,表明o的值,同时经过了filter的过滤,以及根据indent进行了格式化

5.描述

  ①当对象o自身带有toJSON()方法时,JSON.stringify()会调用o的toJSON()方法,并使用该方法的返回值而不是该对象自己进行字符串化;

  ②若是filter存在且是一个函数,那么该函数的返回值将会做为JSON.stringify()方法的返回值。而且该函数接收两个参数,第一个参数是一个空字符串,第二个参数就是对象o。这里,你们也能够参考Douglas Crockford为 ES3 环境使用JSON写的json2:https://github.com/douglascrockford/JSON-js/blob/master/json2.js#L427。看看JSON.stringify和str的实现应该就明白我这里所说的这两个参数的具体含义了;

  ③若是filter存在且是一个字符串数组(若是数组中包含数字,数字会自动转化为字符串),那么对象o的某些属性名若是不在这个数组中,则序列化时会将这些属性省略,且返回的字符串中属性的顺序会与该数组中属性的顺序一致;

  ④JSON.stringify()返回的一般是不带任何空格或换行符的字符串。若是想输出可读性更好的字符串,须要指定第三个参数。若是指定的第三个参数是介于1~10之间的值,则JSON.stringify()会在每一“层级”的输出插入换行符和指定个数的空格。若是指定的第三个参数是非空字符串,则JSON.stringify()会插入换行符和该字符串(只取前十个字符)来缩进层级;

五.完整版JSON.parse()

1.简介

  解析JSON格式的字符串

2.概要

  JSON.parse(s[, reviver])

3.参数

  s,要解析的字符串

  reviver,可选参数,用来转换解析值的可选函数

4.返回

  一个对象、数组或原始值。该返回值是从s中解析的(还有可能被reviver修改过);

5.描述

  ①若是指定了reviver函数,该函数会为从s中解析的每个原始值(不是包含这些原始值的对象或数组)调用一次。调用reviver时带有两个参数,第一个参数是属性名——对象的属性名或转换成字符串的数组序号,第二个参数是对象属性或数组元素的原始值(若是对于这里说的两个参数有疑惑,仍是能够参考:https://github.com/douglascrockford/JSON-js/blob/master/json2.js#L460)。而且,reviver函数的返回值将做为JSON.parse()的返回值;

相关文章
相关标签/搜索