基于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 相关文章推荐
类之Prototype.js学习
Jun 13 Javascript
超级24小时弹窗代码 24小时退出弹窗代码 100%弹窗代码(IE only)
Jun 11 Javascript
自编jQuery插件实现模拟alert和confirm
Sep 01 Javascript
JavaScript用JQuery呼叫Server端方法示例代码
Sep 03 Javascript
JS 对象属性相关(检查属性、枚举属性等)
Apr 05 Javascript
jQuery实现页面内锚点平滑跳转特效的方法总结
May 11 Javascript
javascript相关事件的几个概念
May 21 Javascript
node.js连接mongoDB数据库 快速搭建自己的web服务
Apr 17 Javascript
servlet+jquery实现文件上传进度条示例代码
Jan 25 Javascript
通过V8源码看一个关于JS数组排序的诡异问题
Aug 14 Javascript
在create-react-app中使用css modules的示例代码
Jul 31 Javascript
js实现图片局部放大效果详解
Mar 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 数组遍历顺序理解
2009/09/09 PHP
PHP的几个常用数字判断函数代码
2012/04/24 PHP
php命令行用法入门实例教程
2014/10/27 PHP
php第一次无法获取cookie问题处理
2014/12/15 PHP
php查询相似度最高的字符串的方法
2015/03/12 PHP
AES加解密在php接口请求过程中的应用示例
2016/10/26 PHP
PHP读取Excel类文件
2017/05/15 PHP
PHP利用Socket获取网站的SSL证书与公钥
2017/06/18 PHP
JavaScript 计算当天是本年本月的第几周
2009/03/22 Javascript
JS获取父节点方法
2009/08/20 Javascript
JavaScript DOM学习第六章 表单实例
2010/02/19 Javascript
Javacript实现颜色梯度变化和渐变的效果代码
2013/05/31 Javascript
js复制到剪切板的实例方法
2013/06/28 Javascript
JavaScript必知必会(二) null 和undefined
2016/06/08 Javascript
ionic实现带字的toggle滑动组件
2016/08/27 Javascript
webpack配置文件和常用配置项介绍
2017/04/28 Javascript
js中apply与call简单用法详解
2017/11/06 Javascript
three.js中文文档学习之创建场景
2017/11/20 Javascript
Vue添加请求拦截器及vue-resource 拦截器使用
2017/11/23 Javascript
vue项目base64字符串转图片的实现代码
2018/07/13 Javascript
javascript定时器的简单应用示例【控制方块移动】
2019/06/17 Javascript
小程序瀑布流组件实现翻页与图片懒加载
2020/05/19 Javascript
解决vue动态下拉菜单 有数据未反应的问题
2020/08/06 Javascript
[01:41]DOTA2超级联赛专访YYF 称一辈子难忘TI2
2013/05/28 DOTA
[01:15:00]LGD vs Mineski Supermajor 胜者组 BO3 第一场 6.5
2018/06/06 DOTA
PyCharm 设置SciView工具窗口的方法
2019/01/15 Python
python远程连接MySQL数据库
2019/04/19 Python
Python基于scipy实现信号滤波功能
2019/05/08 Python
python切片的步进、添加、连接简单操作示例
2019/07/11 Python
python 调用pyautogui 实时获取鼠标的位置、移动鼠标的方法
2019/08/27 Python
英国景点门票网站:attractiontix
2019/08/27 全球购物
大学生通用个人的自我评价
2014/02/10 职场文书
基层干部2014全国两会学习心得体会
2014/03/10 职场文书
导游词之泉州崇武古城
2019/12/20 职场文书
Nginx解决前端访问资源跨域问题的方法详解
2021/03/31 Servers
app场景下uniapp的扫码记录
2022/07/23 Java/Android