前端设计

js序列化和反序列化

2019-11-23

js序列化和反序列化

1、序列化

即js中的Object转化为字符串


1)使用obj.toJSONString

var str=obj.toJSONString(); //将JSON对象转化为JSON字符  

2)使用JSON.stringify(obj)

var str=JSON.stringify(obj); //将JSON对象转化为JSON字符  

 

2、反序列化

即js中JSON字符串转化为Object


1)使用eval 既eval('('+jsonStr+')')

var obj=eval("("+data+")");  

为什么要 eval这里要添加 "("+data+");//”呢? 

原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

2)使用parseJSON

var obj = data.parseJSON(); //由JSON字符串转换为JSON对象  

3)使用parse

var obj = JSON.parse(data); //由JSON字符串转换为JSON对象  



3、使用场景


1)向后台传递参数、接收后台返回值

如果后台返回的是一个String(Object序列化后返回),那么需要在js中使用eval或者parse等转化为Object再使用;

如果返回时传递了类型,比如就是Object,那么直接使用就好


2)在页面间传递数据,特别是数组时

需要使用序列化,否则IE会报错:不能执行已经释放Script的代码

3)在进行本地存储时

  存储在本地window.localStorage.setItem(key,value)存储的value是json序列化的字符串;获取得到的window.localSorage.getItem(key)也是json序列化的字符串,需要经过json的反序列化进行使用(常见json序列化数组)