0.前言
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。 这些特性使JSON成为理想的数据交换语言。
JSON大致3种结构,JSON对象、JSON数组和JSON对象和数组嵌套。
1 JSON对象
JSON对象简单而言便是键值对或名值对,而“值”可以是数值、字符串和布尔类型等。
JSON对象具体格式如图1所示。
图1 JSON对象格式
1.1 JSON数值
请注意数值不需要加引号,键值对之间使用","。
【单个数值】
{“value”:12}
【多个数值】
{"maxValue":24, "minValue":12};
<script>
var jsonObj = {"maxValue":24, "minValue":12};
console.log(jsonObj.maxValue);
console.log(jsonObj.minValue);
</script>
【输出】
24
12
1.2 JSON字符串
字符串需要加引号,键值对之间使用","。    
【单个字符串】
{"name":"xukai871105"}
【多个字符串】

{"name":"xukai871105", "blog":"http://blog.csdn.net/xukai871105"}

<script>
var jsonObj = {"name":"xukai871105", "blog":"http://blog.csdn.net/xukai871105"};
console.log(jsonObj.name);
console.log(jsonObj.blog);
</script>

【输出】

xukai871105
http://blog.csdn.net/xukai871105
1.3 JSON布尔
请注意JSON格式中的值可以使用布尔类型,且不需要加引号,如果true或false被引号包裹,那么便解析为JSON字符串,请处理稍有不同。
{"success":false}
<script>
var jsonObj = {"success":false};
console.log(jsonObj.success);
</script>

【输出】
false
2 JSON数组
JSON数组的表达方法和C语言数组的表达方法完全相同。下面的例子中存在一个JSON对象,该JSON对象只有一个键值对,键为lists而键值为JSON数组——[5,6,7,8]。这里已经存在JSON类型的嵌套,具体请看下面一个例子。
{"lists":[5,6,7,8]}
图2 JSON数组格式
<script>
var jsonObj = {"lists":[5,6,7,8]};
console.log(jsonObj.lists);
for(var i=0; i<jsonObj.lists.length; i++) {console.log(jsonObj.lists[i]);
}
</script>

【输出】
[5, 6, 7, 8]
5
6
7
8 

3 JSON嵌套
JSON格式可以嵌套,所谓嵌套便是JSON对象中可包括JSON数组,JSON数组中可包括JSON对象。下面的例子中rows为JSON对象,对象中嵌套JSON数组,每一个JSON数组的元素又是一个JSON对象。这种嵌套情况在实际情况中经常出现。
<script>
var jsonObj =
{
"total": 3,
"rows": [
{
"title": "树莓派学习笔记——索引博文",
"url": "http://blog.csdn.net/xukai871105/article/details/23115627"
},
{
"title": "树莓派学习笔记——GPIO功能学习",
"url": "http://blog.csdn.net/xukai871105/article/details/12684617"
},
{
"title": "物联网学习笔记——索引博文",
"url": "http://blog.csdn.net/xukai871105/article/details/23366187"
}
]
};console.log(jsonObj.total);
for(var i=0; i<jsonObj.rows.length; i++) {console.log(jsonObj.rows[i].title);console.log(jsonObj.rows[i].url);
}
</script>

【输出】
3
树莓派学习笔记——索引博文
http://blog.csdn.net/xukai871105/article/details/23115627
树莓派学习笔记——GPIO功能学习
http://blog.csdn.net/xukai871105/article/details/12684617
物联网学习笔记——索引博文
http://blog.csdn.net/xukai871105/article/details/23366187

4.javascript中eval函数
【为什么要加括号 】
加上圆括号的目的是迫使eval函数在评估JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。参考——【3】 javascript eval和JSON之间的联系
<script>
var jsonStr = '{"total":3}';
var jsonObj= eval('(' + jsonStr + ')');
console.log(jsonObj.total);
</script>

【输出】
3

5.常见错误
【1】多一个逗号
}或]前多一个, 这种情况不符合JSON,但是某些浏览器可以容忍,例如chrome和火狐,但是某些浏览器就无法容忍,例如IE。最好还是选择JSON校验工具测试一下JSON数据包是否合法。请注意下面一个例子中url最后的",",该逗号是多余的。
{
"title": "树莓派学习笔记——索引博文",
"url": "http://blog.csdn.net/xukai871105/article/details/23115627",
}

6.参考资料
【1】 JSON格式化工具
【2】 JSON校验工具
【3】 javascript eval和JSON之间的联系

前端学习——JSON格式详解相关推荐

  1. pm2 start 带参数_pm2 start命令中的json格式详解

    就像苏南大叔所说的那样,pm2 start npm -- start这条命令是pm2的万能命令,pm2 start ,就是这一系列命令中的最豪华命令.这个json我们可以理解为一个任务参数描述文件.通 ...

  2. C语言:JSON格式详解

    C语言:JSON格式详解 C语言:cJSON库用法详解 C语言:使用cJSON库构造JSON C语言:使用cJSON库解析JSON字符串 JSON 简介 JSON全称 JavaScript Objec ...

  3. urlencoded格式详解 JSON格式详解

    一.表单格式详解 [urlencoded格式]:又叫form格式,或者是x-www-form-urlencoded格式. 口诀:表单格式是由键值对组成.键和值之间用=.多个键值对之间用&.例如 ...

  4. urlencoded、json 格式详解

    表单格式详解 概念 urlencoded 格式,又叫 form 格式.x-www-form-urlencoded 格式 它是一种表单格式 组成格式 键值对组成 键和值之间用 = :name=poloy ...

  5. urlencoded格式详解和JSON格式详解

    urlencoded格式详解和JSON格式详解 目录 urlencoded格式详解和JSON格式详解 一.表单格式详解 二.JSON格式详解 [json 格式口诀]: 1.1 什么是JSON 1.2 ...

  6. urlencoded和json 格式详解

    urlencoded 格式,又叫 form 格式.x-www-form-urlencoded 格式 它是一种表单格式 组成格式 键值对组成 键和值之间用 = :name=poloyy 多个键值对之间用 ...

  7. 【cJson】 JSON格式详解

    0.前言 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Programmin ...

  8. 什么是接口测试?接口测试基础、案例及Json格式详解

    很多小伙伴可能会说接口真的有测试的必要吗? 我只要把功能测试好了不就ok了吗? 答案是肯定的,在中大型项目中,后端.前端多人协同开发过程中,接口测试是必要的. 什么是接口(API)测试? API全称( ...

  9. JSON / 格式详解

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式.易于人阅读和编写,同时也易于机器解析和生成. 它基于JavaScript Programming Langu ...

最新文章

  1. 牛X的web报表设计工具Grid++Report
  2. wordpress 介绍
  3. 记录皮尔逊相关系数-相似性比较算法
  4. [Leetcode][第120题][JAVA][三角形最小路径和][动态规划][递归]
  5. 曾逼马云道歉,扬言5年超过阿里!3年后市值差了3万亿 !
  6. C#中将DataTable中数据导出到csv文件中
  7. 类似与fiddler的抓包工具 burp suite free edition
  8. 基于C语言的菜鸟驿站管理系统
  9. js实现鼠标移动到div背景颜色变换,移开还原
  10. leetcode (Find All Numbers Disappeared in an Array)
  11. Redis入门(2):五大数据类型(key,string,list,set,sortset)将其实战,配置文件详解,发布与订阅
  12. minicom 下载
  13. 电脑公司GHOST WIN7 SP1 2011装机旗舰版
  14. c#超火表白小程序(含代码教程)
  15. via浏览器云同步国内服务器网页,Via浏览器
  16. 敏捷ACP.知识总结.错题回顾
  17. HDU 3507 斜率优化入学习
  18. 【Unity】动作游戏开发实战详细分析-16-敌人AI设计
  19. Kaggle Learn 数据泄露(data leakage)的几个例子
  20. ad5764的回读,硬件spi接口

热门文章

  1. 【mmdetection】SSD训练自己的VOC数据集注意事项
  2. 怎么将将PDF图纸转换成CAD格式呢?
  3. uml具有多种视图_UML语言中五大视图
  4. 大数据处理系统都有哪些?(数据查询分析计算系统篇)
  5. 华为网管地址配置实验
  6. 【OpenCV入门到精通之九】OpenCV之视频截取、图片与视频互转
  7. 多用户博客BLOG系统大全
  8. 解答:什么样的企业才适合引入OA办公系统?
  9. LoadRunner之并发用户数与迭代关系---并发数与迭代的区别
  10. IPsec中IKE与ISAKMP过程分析(主模式-消息5和消息6)