Json是什么?以及Json的序列化和反序列化

一.什么是Json:

  中午肚子饿了,到餐厅点餐。向服务员点了几个菜,厨师根据用户的需求,开始烹饪食物,食物烹饪好后,怎么将食物呈现给用户呢?这时就需要用到盛放食物的碗了。用户拿到盛放食物的碗,就可以获得点的餐了。这个碗就充当了数据交换的容器了(^-^)

 

  客户端向服务器端发送请求后,服务器端怎么才能把用户需要的数据返回给客户端呢。这时我们就需要用一个指定的格式将数据,按照指定格式返回客户端。这时就有了两种数据传输的方式(XMLJson):

  在普通的Web应用中,不管是服务器端还是客户端解析XML代码会非常麻烦,所以这时Json就更加满足数据传输解析的要求。采用Json格式的方式进行数据的传输,不仅方便传输解析,还特别易于人阅读和编写

二.XML与Json转换:

1.常规转换:

<emp>
    <name>fxhl</name>
    <city>深圳</city>
    <age>23</age>
</emp>

转换为Json为:

  {“name”:“fxhl”,"city":"深圳","age":23}

三.Json的表现形式:

  1.对象:

复制代码
{
    "returnCode": "R0000",
    "returnMsg": "成功",
    "lessTimes": "2",
    "domainLink": "",
    "seqNum": "1",
    "identification": "595279",
    "isNeedImageCode": "false"
}
复制代码

  2.数组:

复制代码
{
    "employees": [
        { "firstName":"John" , "lastName":"Doe" },
        { "firstName":"Anna" , "lastName":"Smith" },
        { "firstName":"Peter" , "lastName":"Jones" }
    ]
}
复制代码

  3.数组对象混合:

    这是截取的一小部分,对于比较复杂的Json格式的字符串,可以在线验证json。格式化一个格式。方便观看

      • Json的表现形式一般就三种(对象,数组,字符串),使用过程中,只是将对象与数组进行混合了
复制代码
{
    "icon": [
        {
            "title": "尚天猫,就购了",
            "icon_category": "baobei",
            "icon_key": "icon-service-tianmao",
            "trace": "srpservice",
            "innerText": "天猫宝贝",
            "url": "//www.tmall.com/"
        },
        {  
            "title": "保险理赔",
            "position": "99",
            "innerText": "分组-保险理赔",
            "iconPopupComplex": 
        {
                "popup_title": "保险理赔",
                "subIcons": [
                    {
                        "dom_class": "icon-service-yunfeixian",
                        "icon_content": "卖家赠送退货运费险"
                    }
                ]
            }
        }
    ]
}
复制代码

4..Json序列化和解析

JSON.stringify( ) —— 将对象序列化为JSON字符串

JSON.parse( ) —— 将JSON数据解析为Javascript对象

默认情况下JSON.stringify( )输出的JSON字符串不包含任何空格字符或缩进;此外,值为undefined的任何属性也都会被跳过,结果都是有效的JSON数据类型。

实际上,JSON.stringify( )除了要序列化javascript对象之外,还可以接收两个参数(用于指定以不同方式序列化javascript):1.第一个参数是过滤器(可为数组或函数) 2.第二个参数是一个选项(表示是否在JSON字符串中保留缩进)

4.1过滤结果

  •  如果过滤器的参数是数组,那么JSON.stringify( )的结果将只包含数组中列出的属性。

      

注意:第二个数组中的两个字段要与json中的属性对应。

输出结果:(jsonText的值)

 

  • u如果第二个参数是函数(传入的函数接收两个属性,属性(键)名和属性值):


输出结果:(jsonText的值)


可以看到如果键为edition,通过返回undefined删除该属性。一定要提供default项,使其他值可以显示在结果中

 

4.12字符串的缩进

JSON.stringify( )方法的第三个参数用于控制结果的缩进和空白符。如果这个参数是一个树枝那么他表示的是每个级别的缩进空格。

例:要每个级别缩进4个空格

var jsonText=JSON.stringify(book,null,4)

注:最大缩进空格为10,所有大于10的值都会被自动转换为10.

4.13 tojson()方法

有时候JSON.stringify( )不能满足自动序列化的需求。这时就可以给对象定义toJson( )方法。

                      

结果输出:

                    

toJSON( )方法可以作为函数过滤器的补充。假设把一个对象传入JSON.stringify(),序列化该对象的顺序:

(1)如果存在toJSON( )方法且能通过它取得有效的值,则调用该方法,否则返回JSON本身。

(2)如果提供了第二个参数,应用这个过滤器,传入过滤器的值是第(1)步返回的值(其实结果就是,上述的jsonText输出结果是toJSON()方法返回的值)

(3)如果提供了第三个参数,执行相应的格式化操作。

4.2解析结果

JSON.parse()方法也可以接收另一个参数,该参数是个函数,将在每个键值对上调用。为了区别去JSON.stringify(),这个函数被称作还原函数

如果还原函数返回undefined则删除该键,如果返回其他值,则将键插入到结果中去。

例:在日期字符串转化为Date对象时,经常用到还原函数

                

输出结果:

              

小结:之前看到这样一句话:“JSON对象要求给属性加双引号,忘了给对象属性名加双引号而写成单引号都是常见的错误”,我发现我写json到现在写属性名的时候经常没有加引号。 说道这里。。突然发现。。。上面的截图json属性有些没有加双引号。。。这。。。  已经不想重新截图了  就这样吧



猜你喜欢

转载自blog.csdn.net/pupilxiaoming/article/details/80988013