基于JSON数据格式详解


Posted in Javascript onAugust 31, 2017

JSON是行业内使用最为广泛的数据交换格式,在很多场景都有广泛的应用。JSON适用于进行数据交互的场景,典型的是Ajax中实现异步加载;为了支持跨平台、数据安全等的Web Service也可以使用(API接口返回值)。

JSON(JavaScript Object Notation)是一种完全独立于语言的、轻量级的数据交换格式。它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。JSON的官方MIME类型是application/json,文件扩展名是 .json。

优点:易于人阅读和编写。同时也易于机器解析和生成。支持众多语言。

JSON建构于两种结构:

· “名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array)。

· 值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。

JSON具有以下这些形式:

Object是一个无序的“‘名称/值'对”集合。一个对象以“{”开始,“}”结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”分隔。

Array是值(value)的有序集合。一个数组以“[”开始,“]”结束。值之间使用“,”分隔。

值(value)可以是双引号括起来的字符串(string)、数值(number)、true、false、 null、对象(object)或者数组(array)。这些结构可以嵌套。

基本类型:

string、number、 true、false、 null。

字符串(string)是由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。一个字符(character)即一个单独的字符串(character string)。

JSON实例

{
 "name":"Python学习者",
 "age":20,
 "course":["Java","Python"],
 "job":null,
 "url":"https://3water.com"
}

JavaScript

<html>
<head>
 <meta charset="utf-8">
 <title>Pyhton学习者-JSON</title>
</head>
<body>
 <p>使用" . "访问JSON对象</p>
 <p id="demo1"></p>
 <p>使用" [] "访问JSON对象</p>
 <p id="demo2"></p>

<script>
 var obj, name, age;
 obj =  {
  "name":"Python学习者",
  "age":20,
  "course":["Java","Python"],
  "job":null,
  "url":"https://3water.com"
 }
 name = obj.name;
 document.getElementById("demo1").innerHTML = name;
 age = obj["age"];
 document.getElementById("demo2").innerHTML = age;
</script>

</body>
</html>

MongoDB

MongoDB是一种常用的NoSQL数据库,它所有的信息都是按照文档保存的,保存的结构就是JSON结构。

db.students.insert({"name" : "张三" , "sex" : "男" , "age" : 18 , "score" : 85 });
db.students.insert({"name" : "李四" , "sex" : "女" , "age" : 21 , "score" : 93 });
db.students.insert({"name" : "王五" , "sex" : "女" , "age" : 19 , "score" : 68 });
db.students.find("name":"张三");

其实JSON结构并不难理解,需要注意的是"key/value"中,key是string类型,要使用 ""(双引号)。

参考资料:

在线代码格式化:http://tool.oschina.net/codeformat/json

JSON官方网站:http://www.json.org/

以上这篇基于JSON数据格式详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
新浪中用来显示flash的函数
Apr 02 Javascript
9个JavaScript评级/投票插件
Jan 18 Javascript
js常用代码段整理
Nov 30 Javascript
Microsfot .NET Framework4.0框架 安装失败的解决方法
Aug 14 Javascript
javascript的数组和常用函数详解
May 09 Javascript
PHP+jQuery实现随意拖动层并即时保存拖动位置
Apr 30 Javascript
jQuery绑定事件方法及区别(bind,click,on,live,one)
Aug 14 jQuery
select自定义小三角样式代码(实用总结)
Aug 18 Javascript
原生JS 购物车及购物页面的cookie使用方法
Aug 21 Javascript
从setTimeout看js函数执行过程
Dec 19 Javascript
手淘flexible.js框架使用和源代码讲解小结
Oct 15 Javascript
webstorm+vue初始化项目的方法
Oct 18 Javascript
浅谈js中的this问题
Aug 31 #Javascript
js实现图片放大展示效果
Aug 30 #Javascript
详解js几个绕不开的事件兼容写法
Aug 30 #Javascript
JavaScript实现滑动导航栏效果
Aug 30 #Javascript
详解vue-cli 构建Vue项目遇到的坑
Aug 30 #Javascript
前端开发不得不知的10个最佳ES6特性
Aug 30 #Javascript
vue.js的手脚架vue-cli项目搭建的步骤
Aug 30 #Javascript
You might like
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
$_GET['goods_id']+0 的使用详解
2013/06/06 PHP
PHP批量去除BOM头代码分享
2015/06/26 PHP
php有效防止同一用户多次登录
2015/11/19 PHP
完美解决phpexcel导出到xls文件出现乱码的问题
2016/10/29 PHP
Yii2框架实现数据库常用操作总结
2017/02/08 PHP
Laravel 实现密码重置功能
2018/02/23 PHP
PHP获取MySQL执行sql语句的查询时间方法
2018/08/21 PHP
改进:论坛UBB代码自动插入方式
2006/12/22 Javascript
解决使用attachEvent函数时,this指向被绑定的元素的问题的方法
2007/08/13 Javascript
Jquery 设置标题的自动翻转
2009/10/03 Javascript
js+HTML5实现视频截图的方法
2015/06/16 Javascript
Jquery插件仿百度搜索关键字自动匹配功能
2016/05/11 Javascript
jquery 标签 隔若干行加空白或者加虚线的方法
2016/12/07 Javascript
详解vue-cli开发环境跨域问题解决方案
2017/06/06 Javascript
彻底搞懂JavaScript中的apply和call方法(必看)
2017/09/18 Javascript
JS实现按钮添加背景音乐示例代码
2017/10/17 Javascript
js实现Element中input组件的部分功能并封装成组件(实例代码)
2021/03/02 Javascript
[05:15]2018年度CS GO社区贡献奖-完美盛典
2018/12/16 DOTA
python之import机制详解
2014/07/03 Python
python进阶教程之循环对象
2014/08/30 Python
Python实现Tab自动补全和历史命令管理的方法
2015/03/12 Python
Python通过PIL获取图片主要颜色并和颜色库进行对比的方法
2015/03/19 Python
python魔法方法-自定义序列详解
2016/07/21 Python
Python OpenCV读取png图像转成jpg图像存储的方法
2018/10/28 Python
Python利用matplotlib做图中图及次坐标轴的实例
2019/07/08 Python
使用Rasterio读取栅格数据的实例讲解
2019/11/26 Python
html5唤醒APP小记
2019/03/27 HTML / CSS
深深扎根运动世界的生活品牌:Tillys
2017/10/30 全球购物
以思科路由器为例你写下单臂路由的配置命令
2013/08/03 面试题
销售岗位职责范本
2014/06/12 职场文书
公司新人试用期自我评价
2014/09/17 职场文书
2014广电局实施党的群众路线教育实践活动方案思想汇报
2014/09/22 职场文书
安全承诺书格式范本
2015/04/28 职场文书
Python3的进程和线程你了解吗
2022/03/16 Python
Vue深入理解插槽slot的使用
2022/08/05 Vue.js