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 ...
随机推荐
- 发送邮件的小功能(.net core 版)
前言: 使用.net core 开发有一段时间了,期间从.net core 2.0 preview1 到 preview2 又到core 1.1 现在2.0正式版出来了.又把项目升级至2.0了.目前正 ...
- linux下boost的安装与编译
1.从boost官网下载boost库包: 2.然后解压到linux下的任意一个文件夹, 3.进入boost_1_57文件夹下,不同的boost版本会解压城不同的库文件夹, 4.执行././bootst ...
- Leetcode刷题C#版之 Median of Two Sorted Arrays
题目: There are two sorted arrays nums1 and nums2 of size m and n respectively. Find the median of the ...
- Git团队协作之GitFlow & SoucceTree
GitFlow 定义了一个围绕项目发布的严格的分支模型,仍然使用中央仓库作为开发者的交互中心 GitFlow分支 Master分支 Hotfix紧急修改 Release分支 Develop开发分支 F ...
- Angular4.0用命令行创建组件服务出错
之前使用cnpm创建的angular4.0项目,由于cnpm下载的node_modules资源经常会有部分缺失,所以在用命令行创建模板.服务的时候会报错: Error: ELOOP: too many ...
- 对于 @Autowired注解和@service注解的理解
@Autowired相当于Spring自动给你进行了new一个对象将这个对象放入你的注解所在类里面. @service 是可以让IOC容器对于你注解的类可以在容器中生成相应的bean实例 便于我们进行 ...
- javascript类型判断方法
判断javascript中的类型,共有四种常用的方法 var a=6; var b="str"; var c=true; var arr=[]; typeof 用于基本类型的判断 ...
- HttpClient调用RestFul接口(post和get方式)
/** * @version V1.0 * @Description 调用http接口工具类 * @Author pc * @Date 2018/3/2 11:03 */public class Ht ...
- PyQt5多点触控写字板实现及困惑
Qt支持程序多点触控,就想使用PyQt5做一个触控画板,经过几番周折,查阅了TouchEvent官方文档,又参考了一篇QT for Android的例子,采用eventfilter过滤器来识别触屏事件 ...
- caffe+CPU︱虚拟机+Ubuntu16.04+CPU+caffe安装笔记
由于本机是window10系统,所以想尝试caffe就在自己电脑上整了一个虚拟机(详情可见:win10系统搭建虚拟机:VMware Workstation Player 12环境+Ubuntu Kyl ...