zoukankan      html  css  js  c++  java
  • 数据格式JSON

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

    可以创建一个新的 JavaScript 变量,然后将 JSON 格式的数据字符串直接赋值给它:

    var people = { "programmers": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" },

    { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb" },

    { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" }

    ],

    "authors": [

    { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },

    { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },

    { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }

    ],

    "musicians": [

    { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },

    { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }

    ] }

    上面的长字符串实际上只是一个数组;将这个数组放进 JavaScript 变量之后,就可以很轻松地访问它。实际上,只需用点号表示法来表示数组元素。所以,要想访问 programmers 列表的第一个条目的姓氏,只需在 JavaScript 中使用下面这样的代码:

    people.programmers[0].lastName;

    people.authors[1].genre // Value is "fantasy"

    people.musicians[3].lastName // Undefined. This refers to the fourth entry, and there isn't one

    people.programmers[2].firstName // Value is "Elliotte"

    修改 JSON 数据

    正如可以用点号和括号访问数据,也可以按照同样的方式轻松地修改数据:

    people.musicians[1].lastName = "Rachmaninov";

    在将字符串转换为 JavaScript 对象之后,就可以像这样修改变量中的数据。

    转换回字符串

    当然,如果不能轻松地将对象转换回本文提到的文本格式,那么所有数据修改都没有太大的价值。在 JavaScript 中这种转换也很简单:

    String newJSONtext = people.toJSONString();

    这样就行了!现在就获得了一个可以在任何地方使用的文本字符串,例如,可以将它用作 Ajax 应用程序中的请求字符串。

    XML和JSON都使用结构化方法来标记数据,下面来做一个简单的比较。

    用XML表示中国部分省市数据如下:

    <?xml version="1.0" encoding="utf-8"?>

    <country>

        <name>中国</name>

        <province>

            <name>黑龙江</name>

         <cities>

                <city>哈尔滨</city>

                <city>大庆</city>

            </cities>

        </province>

        <province>

            <name>广东</name>

            <cities>

                <city>广州</city>

                <city>深圳</city>

                <city>珠海</city>

            </cities>

        </province>

    </country>

    用JSON表示如下:

    {

    {name:"中国", province:[ { name:"黑龙江", cities:{ city:["哈尔滨","大庆"] },

    {name:"广东", cities:{ city:["广州","深圳","珠海"] } 

    }

    BeJson,一款JSON工具

    1. JSON格式化校验

    很多人在得到JSON数据后,一时没有办法判断JSON数据格式是否正确,是否少或多符号而导致程序不能解析,这个功能正好能帮助大家来完成JSON格式的校验。

    2. JSON视图

    想必很多程序员都会遇到当找一个节点的时候,会发现如果直接对着一行行数据无从下手,就算知道哪个位置,还要一个节点一个节点的往下找,万一一不留神又得从头开始找的麻烦事。

    有了这个功能,一切JSON数据都会变成视图格式,一目了然,什么对象下有多少数组,一个数组下有多少对象。

    这个功能非常实用。不光有视图功能还有格式化、压缩、转义、校验功能。总之很强大。

    3. 压缩转义

    程序员在写JSON语句测试用例的时候,很多时候为了方便直接写了个JSON字符串做测试,但是又陷入了无止境的双引号转义的麻烦中。这款功能集压缩、转义于一身。

    4. JSON在线编辑器

    5. 在线发送JSON数据

    大家都知道,JSON用的最多的还是web项目的开发,那你要测试一个接口是否能准确的接受JSON数据,那你就得写一个页面发送JSON字符串,重复的做着这件事。随着这个功能的横空出世,你可以摆脱写测试页面了,因为这个功能可以将指定的JSON数据发送指定的url,方便吧。

    6. JSON着色

    很多人在写文档时,总希望文档能一目了然,但是面对着白底黑字的JSON数据总是提不起精神没关系,使用这个功能,所有的关键字都会被着色,数据结构一目了然。

    7. JSON-XML互转

    参考文章

    http://www.cnblogs.com/SkySoot/archive/2012/04/17/2453010.html

  • 相关阅读:
    form表单为什么不能提交
    遇到了消息堆积,但是问题不大
    面试题:如何保证消息不丢失?处理重复消息?消息有序性?消息堆积处理?
    Dubbo学习地址
    Dubbo入门到实战2
    Dubbo入门到实战
    Mybatis 的三种执行器
    从源码理解Druid连接池原理
    Getting NoSuchMethodError:javax.servlet.ServletContext.getVirtualServerName()
    解决问题:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
  • 原文地址:https://www.cnblogs.com/lxzbky/p/7072635.html
Copyright © 2011-2022 走看看