zoukankan      html  css  js  c++  java
  • js的序列化和反序列化

    (1)序列化

                   即js中的Object转化为字符串

                   1.使用toJSONString

    [javascript] view plain copy
    1. var last=obj.toJSONString(); //将JSON对象转化为JSON字符  

                  2.使用stringify

    [javascript] view plain copy
    1. var last=JSON.stringify(obj); //将JSON对象转化为JSON字符  

    (2)反序列化

                   即js中JSON字符串转化为Object

                   1.使用eval

    [javascript] view plain copy
    1. var obj=eval("("+data+")");  

                 为什么要 eval这里要添加 "("+data+");//”呢? 
                 原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。
                   2.使用parseJSON

    [javascript] view plain copy
    1. var obj = data.parseJSON(); //由JSON字符串转换为JSON对象  

                   3.使用parse

    [javascript] view plain copy
    1. var obj = JSON.parse(data); //由JSON字符串转换为JSON对象  



    (3)使用场景

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

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

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

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

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

  • 相关阅读:
    故乡
    webService和Restful
    java多线程(六)线程控制类
    java内存模型
    java多线程(五)线程通讯
    java多线程(四)死锁
    java多线程(三)线程的安全问题
    java多线程(二)线程的生命周期
    java多线程(一)创建线程的四种方式
    Spring Cloud(一)简单的微服务集成Eureka
  • 原文地址:https://www.cnblogs.com/fengff/p/8073967.html
Copyright © 2011-2022 走看看