To Noob Json是什么鬼?

To Noob Json是什么鬼?

大家好,又见面了,我是全栈君。

转载请注明出处王亟亟的大牛之路
供应商A:那我们数据怎么交互啊?HTTP吧?那内容呢?JSON?XML?
小菜鸟B:JSON什么鬼?
为了菜鸟们避免以上情况楼主写一发JSON的博文,废话不多!開始!

先梳理下概念
1.JSON是什么
JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)
JSON 是轻量级的文本数据交换格式
JSON 独立于语言 *
JSON 具有自我描写叙述性,更易理解
JSON 使用 Javascript语法来描写叙述数据对象,可是 JSON 仍然独立于语言和平台。

JSON 解析器和 JSON 库支持很多不同的编程语言。

眼下非常多的动态(PHP,JSP。.NET)编程语言都支持JSON。

2.JSON和XML的同样点以及不同点
同样:
JSON 是纯文本
JSON 具有”自我描写叙述性”(人类可读)
JSON 具有层级结构(值中存在值)
JSON 可通过 JavaScript 进行解析
JSON 数据可使用 AJAX 进行传输
不同:
没有结束标签
更短
读写的速度更快
可以使用内建的 JavaScript eval() 方法进行解析
使用数组
不使用保留字

样例:
简单的JSON对象

{
    "name": "wjj"
}
简单的样例。这是一个叫name的json对象,属性是字符串wjj。
{
    "action": 123
}
我们办了变,他如今有一个属性。只是是int型的。值是123.

在我们人工读的时候,非常轻易就能解读那一段json字符串

JSON的数据类型
JSON 值可以是:

数字(整数或浮点数)
字符串(在双引號中)
逻辑值(true 或 false)
数组(在方括号里)
对象(在花括号里)
null

实例
要被解析的json字符串

{
    "phone": [ "1000000", "2000000" ],
    "name": "wjj",
    "age": 20,
    "address": { "country": "china", "province": "shanghai" },
    "married": false }

上面这段json字符串简单的说明了一个人的一些属性,各种类型的数据一目了然,那我们来试着写写这段JSON.

try {  
    // 首先最外层是{},是创建一个对象 
    JSONObject person = new JSONObject();  
    // 第一个键phone的值是数组。所以须要创建数组对象 
    JSONArray phone = new JSONArray();  
    phone.put("1000000").put("2000000");  
    person.put("phone", phone);  

    person.put("name", "wjj");  
    person.put("age", 20);  
    // 键address的值是对象,所以又要创建一个对象 
    JSONObject address = new JSONObject();  
    address.put("country", "china");  
    address.put("province", "shanghai");  
    person.put("address", address);    
    person.put("married", false);  
} catch (JSONException ex) {  
    // 键为null或使用json不支持的数字格式(NaN, infinities) 
    throw new RuntimeException(ex);  
}  

然后 再试着拆这段JSON

try {

    JSONObject jsonObject = new JSONObject(jsonData);
    person.phoneArray=jsonObject.optJSONArray("phone ");
    person.name=jsonObject.optString("name");
    person.age=jsonObject.optInt("age");
    JSONArray jsonObject1=jsonObject.opJSONArray("address");
    person.country=jsonObject1.opString("country");
    person.province=jsonObject1.opString("province");
    person.married=jsonObject.opBoolean("married"); 
     } catch (JSONException e) {
            e.printStackTrace();
        }

就是如此。一层一层拨开,逻辑非常清晰哦。

再推荐一些方便平时读JSON的地址 :
http://www.bejson.com/
http://json.cn/

今天就到这里。谢谢大家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115465.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 可执行文件的组成

    可执行文件的组成在ADS下,可执行文件有两种,一种是.axf文件,带有调试信息,可供AXD调试工具使用.另一种是.bin文件,可执行的二进制代码文件。我们重点是讲描.bin文件的组成。我们把可执行文件

    2022年8月2日
    6
  • trunk链路的配置命令_链路聚合配置

    trunk链路的配置命令_链路聚合配置实验环境使用之前用过的GNS3、WireShark和CRT进入GNS3页面,点击左侧图标菜单栏,拖入2台路由器到拓扑操作台,再点击PC图标,选择VPC,拖入拓扑操作台,配置两台路由器(更改名称、更改图标、添加二层业务单板、添加磁盘容量为128Mb)—————-配置环境————-1、接下来用网线把PC和路由器连接起来将PC1连到SW1的f1/0将PC2连…

    2025年6月30日
    2
  • ASP.NET使用UpdatePanel实现AJAX

    ScriptManager和UpdatePanel控件联合使用可以实现页面异步局部更新的效果。其中的UpdatePanel就是设置页面中异步局部更新区域,它必须依赖于ScriptManager存在,

    2021年12月21日
    50
  • 几种页面跳转方法_HTML页面跳转的方法

    几种页面跳转方法_HTML页面跳转的方法页面跳转方式1——herf在一些html的文档中,用herf实现页面跳转的比较常见,也很好用。页面跳转方式2——利用表单action页面跳转方式3——response.sendRedirect(

    2022年8月5日
    23
  • 巴伦电路基础_巴伦变压器

    巴伦电路基础_巴伦变压器本文转自博文:http://whoshallwe.blog.163.com/blog/static/5074415520127723238151/需要巴伦的原因?   差分电路具有高增益、抗电磁干扰、抗电源噪声、抗地噪声能力很高、抑制偶次谐波等优点。如今,在RF电路和低频电路中,差分电路的使用越来越广泛。所以,巴伦的重要性也与日俱增。balun短语分析balun是由“balanc

    2025年6月10日
    3
  • vue 子组件调用父组件方法传参,父组件调用也传参_面试题vue组件封装思路

    vue 子组件调用父组件方法传参,父组件调用也传参_面试题vue组件封装思路父组件vueprivateScoreTop:msg=”Widget”v-on:listenTochildEvent=”showMessageFromChild”>privateScoreTop>父组件jsexportdefault{data(){return{}},computed:{p

    2022年9月1日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号