json格式数据整理
一,json的两种数据结构
1.1,对象
对象结构以”{”大括号开始,以”}”大括号结束。中间部分由0或多个以”,”分隔的”key(关键字)/value(值)”对构成,关键字和值之间以”:”分隔,语法结构如代码。
{
key1:value1,
key2:value2,
...
}
1.2,数组
其中关键字是字符串,而值可以是字符串,数值,true,false,null,对象或数组
数组结构以”[”开始,”]”结束。中间由0或多个以”,”分隔的值列表组成,语法结构如代码。
[
{
key1:value1,
key2:value2
},
{
key3:value3,
key4:value4
}
]
二,json格式的升级
2.1,一级-----key,value键值对
是一个个键值对
其中key可以带“”,也可以不带
Code: "414500",
或者这种的
"Code": "414500",
都对。
2.2,二级-----对象
{
"Code": "414500",
"Name": "二七区",
"sort": 1
}
json格式的数据在升级是一个对象,这种对象的格式就类似于这种的,注意最后一个没有,号
2.3,三级-----数组
[
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
]
json格式在对象的基础上会把一个个的对象放到数组当中成为一个数组
2.4,四级-----对象
{
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
]
}
假如现在再把这个数据赋给一个对象,那么它现在又从数据变成对象了,level相当于key,而整个数组就是value
2.5,五级-----对象
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
}
,现在是往已有的对象里面添加新的数据,是对对象的补充。
2.6,六级-----数组
[
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
},
{
"Code": "414530",
"Name": "新乡市",
"level": [
{
"Code": "414530",
"Name": "卫滨区",
"sort": 1
},
{
"Code": "414530",
"Name": "牧野区",
"sort": 2
}
],
"sort": 2
}
]
现在在把这个对象当成数组的0号元素放到一个数据中去。
2.7,七级-----对象
{
"level": [
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
},
{
"Code": "414530",
"Name": "新乡市",
"level": [
{
"Code": "414530",
"Name": "卫滨区",
"sort": 1
},
{
"Code": "414530",
"Name": "牧野区",
"sort": 2
}
],
"sort": 2
}
]
}
(第三步很像)
假如现在再把这个数据赋给一个对象,那么它现在又从数据变成对象了,level相当于key,而整个数组就是value
2.8,八级-----对象
{
"Code": "410000",
"Name": "河南省",
"level": [
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
},
{
"Code": "414530",
"Name": "新乡市",
"level": [
{
"Code": "414530",
"Name": "卫滨区",
"sort": 1
},
{
"Code": "414530",
"Name": "牧野区",
"sort": 2
}
],
"sort": 2
}
]
}
第四步很像
2.9,九级-----数组
[
{
"Code": "940000",
"Name": "澳门特别行政区",
"level": [
{
"Code": "940000",
"Name": "澳门特别行政区",
"level": [
{
"Code": "940000",
"Name": "澳门特别行政区",
"sort": 1
}
],
"sort": 1
}
]
},
{
"Code": "410000",
"Name": "河南省",
"level": [
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
},
{
"Code": "414530",
"Name": "新乡市",
"level": [
{
"Code": "414530",
"Name": "卫滨区",
"sort": 1
},
{
"Code": "414530",
"Name": "牧野区",
"sort": 2
}
],
"sort": 2
}
]
}
]
2.10,10级-----把数组赋给对象(与前面的有点不一样),注意这个不是json格式的数据
{cityData=
[
{
"Code": "940000",
"Name": "澳门特别行政区",
"level": [
{
"Code": "940000",
"Name": "澳门特别行政区",
"level": [
{
"Code": "940000",
"Name": "澳门特别行政区",
"sort": 1
}
],
"sort": 1
}
]
},
{
"Code": "410000",
"Name": "河南省",
"level": [
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
},
{
"Code": "414530",
"Name": "新乡市",
"level": [
{
"Code": "414530",
"Name": "卫滨区",
"sort": 1
},
{
"Code": "414530",
"Name": "牧野区",
"sort": 2
}
],
"sort": 2
}
]
}
]
}
这个对象当中可以添加非json格式的数据,如下
2.11,11级-----对象
{cityData=
[
{
"Code": "940000",
"Name": "澳门特别行政区",
"level": [
{
"Code": "940000",
"Name": "澳门特别行政区",
"level": [
{
"Code": "940000",
"Name": "澳门特别行政区",
"sort": 1
}
],
"sort": 1
}
]
},
{
"Code": "410000",
"Name": "河南省",
"level": [
{
"Code": "414500",
"Name": "郑州市",
"level": [
{
"Code": "414500",
"Name": "二七区",
"sort": 1
},
{
"Code": "414500",
"Name": "中原区",
"sort": 2
}
],
"sort": 1
},
{
"Code": "414530",
"Name": "新乡市",
"level": [
{
"Code": "414530",
"Name": "卫滨区",
"sort": 1
},
{
"Code": "414530",
"Name": "牧野区",
"sort": 2
}
],
"sort": 2
}
]
}
],applyId=1711101632412997, wxOpenId=ogM9Bt0dTFX20JeMjMTFFqVAY2go, ext1=null, ext2=null, ext3=null, orderParam={}, wxModuleType=quliYhxkz, isFirst=true
}
三,json字符串与json对象的区别
字符串:这个很好解释,指使用“”双引号或’’单引号包括的字符。例如:var comStr = 'this is string';
json字符串:指的是符合json格式要求的js字符串。例如:var jsonStr = "{StudentID:'100',Name:'tmac',Hometown:'usa'}";
json对象:指符合json格式要求的js对象。例如:var jsonObj = { StudentID: "100", Name: "tmac", Hometown: "usa" };
四,json数据的应用
未完待续。。。。。。
json格式数据整理的更多相关文章
- iOS开发之JSON格式数据的生成与解析
本文将从四个方面对IOS开发中JSON格式数据的生成与解析进行讲解: 一.JSON是什么? 二.我们为什么要用JSON格式的数据? 三.如何生成JSON格式的数据? 四.如何解析JSON格式的数据? ...
- 解析json格式数据
实现目标 读取文件中的json格式数据,一行为一条json格式数据.进行解析封装成实体类. 通过google的Gson对象解析json格式数据 我现在解析的json格式数据为: {",&qu ...
- ios网络学习------6 json格式数据的请求处理
ios网络学习------6 json格式数据的请求处理 分类: IOS2014-06-30 20:33 471人阅读 评论(3) 收藏 举报 #import "MainViewContro ...
- fastJson java后台转换json格式数据
什么事JSON? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Progra ...
- ajax请求后台,返回json格式数据,模板!
添加一个用户的时候,需要找出公司下所有的部门,和相应部门下的角色,利用ajax请求,实现联动技术.将返回的json格式数据,添加到select标签下. <script type="te ...
- 使用C#中JavaScriptSerializer类将对象转换为Json格式数据
将对象转换为json格式字符串: private JavaScriptSerializer serializer = new JavaScriptSerializer(); protected voi ...
- 使用getJSON()方法异步加载JSON格式数据
使用getJSON()方法异步加载JSON格式数据 使用getJSON()方法可以通过Ajax异步请求的方式,获取服务器中的数组,并对获取的数据进行解析,显示在页面中,它的调用格式为: jQuery. ...
- Ajax返回html和json格式数据
Ajax可以返回text和xml格式 可以用Ajax返回大段的html文本和json格式的字符串,然后用eval()方法 转化为json对象 php中的json编码:json_encode(); ph ...
- 实现android上解析Json格式数据功能
实现android上解析Json格式数据功能,该源码转载于安卓教程网的,http://android.662p.com ,个人感觉还不错的,大家可以看看一下吧. package com.practic ...
随机推荐
- BZOJ 4514: [Sdoi2016]数字配对 [费用流 数论]
4514: [Sdoi2016]数字配对 题意: 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ai/aj 是一个质数 ...
- CF 741D. Arpa’s letter-marked tree and Mehrdad’s Dokhtar-kosh paths [dsu on tree 类似点分治]
D. Arpa's letter-marked tree and Mehrdad's Dokhtar-kosh paths CF741D 题意: 一棵有根树,边上有字母a~v,求每个子树中最长的边,满 ...
- Python tutorial阅读之Python基本运算与基本变量
将 Python 当做计算器 除法运算 用/表示除法运算时,一般得到的是浮点数,如果我们需要得到整数,可以用运算符// 余数计算 % 幂乘方 系统内置变量_ 内置变量_,存储了最近的结果.如图 字符串 ...
- 高仿QQ Xplan的H5页面
概述 这个h5的主要玩法很简单:地球自转的时候会播放背景音乐(比如海浪声),为了找到这个声音是从哪个地球上哪个地方传来的,需要长按下方的按钮,这时地球会自动转动到目标地点,然后镜头拉近,穿过云层,最后 ...
- golang验证提交的数据中某个字段是否重复
提交的json数据如下: { , , , ", , , "screen_mode": "3,2", , "ad_plats":[ ...
- iOS 开发 atomic 与 nonatomic 区别
atomic : 变量默认是有该有属性的,这个属性是为了保证在多线程的情况下,编译器会自动生成一些互斥加锁的代码,避免该变量的读写不同步的问题. nonatomic : 如果该对象无需考虑多线程的 ...
- ubuntu16 ftp 服务 vsftp 配置
转载:沐心_ 地址:http://bbs.csdn.net/topics/392186116------------------------------------------------------ ...
- 流式计算与计算抽象化------《Designing Data-Intensive Applications》读书笔记15
上篇的内容,我们探讨了分布式计算中的MapReduce与批处理.所以本篇我们将继续探索分布式计算优化的相关细节,并且分析MapReduce与批处理的局限性,看看流式计算是否能给我们在分布式计算层面提供 ...
- ubuntu Emergency Mode
sudo fsck -y /dev/sda# e2fsck -f -y -v -C 0 /dev/sda#
- WPF 照片墙的实现
主要参照了DevExpress的PhotoGallery实例的实现. 效果如下: 照片墙核心代码如下: PhotoGallery.xaml <local:CarouselDemoModule x ...