JSON:JavaScript对象表示法

1.1 JSON说明

曾经一段时间,XML是互联网传递数据的统一标准,但是业界一直不乏质疑XML的人士,他们都认为XML过于繁琐,冗长;提取数据也过于麻烦

2006年,JSON被提交给了IETF;在这之后,JSON逐渐发展起来,在互联网上得到广泛应用;

我们要记住:JSON只是一种数据格式,主要用来传递数据,并不是一种编程语言,虽然与JavaScript的语法相似,但是并不是JavaScript才使用JSON,毕竟JSON只是一种数据格式,很多编程语言都有针对JSON的解析器和序列化器

1.2 JSON语法

(1)基础语法:

  • 将JavaScript数据转化为JSON数据,也叫——序列化
// 把JavaScript对象序列化成JSON字符串
var jsonText = JSON.stringify(book);
  • 将JSON数据转化为JavaScript数据,也叫——解析
// 将JSON对象解析成原生JavaScript值
var js = JSON.parse(jsonText);

(2)JSON可以表示以下三种类型的数据:

简单值:可以在JSON里面表示 数值、字符串、布尔值、null不支持 undefined

对象:复杂数据类型,保存一组键值对;在JSON里,对象的键一定要加双引号,值可以是简单值,也可以是复杂数据类型的值

数组:复杂数据类型,保存一组值;值可以是简单值,也可以是复杂数据类型的值

JSON不支持变量,函数,对象实例等,它只是一种表示数据的格式,里面只用来存储数据,不会有逻辑、操作等代码在里面

  • 简单值,简单值中的字符串必须使用双引号,使用单引号报错

    number、string、bool、null
  • 对象,直接使用{ }符号,没有变量,括号后面不用加分号;同一个对象中不应该有相同的属性,以下两个location属性,分别属于不同对象,这样是没有问题的;

    {
    "name": "过青年",
    "age": 20,
    "arr": [1,2,3,4],
    "location": "江西宜春",
    "school": {
    "location": "江西南昌"
    }
    }
  • 数组,直接使用[ ]符号,里面简单值和复杂数据类型可以组合使用,构成更复杂的数据集合;

    [
    20,
    {
    "name": "过青年",
    "age": 20
    },
    [1,2,3],
    "过青年"
    ]

对象和数组一般是JSON数据最外层的结构,利用它们可以创造出各种各样的数据集合

1.3 序列化和解析

1.31 序列化选项

(1)过滤结果

JSON.stringify(js对象,过滤器参数)方法可以传递两个参数

  • 如果过滤器参数是数组,那么JSON.stringify( )的结果将只包含数组中列出的属性

    var obj = {
    name: "过青年",
    age: 20,
    arr: [1,2,3,4],
    location: "江西宜春",
    school: {
    location: "江西南昌"
    }
    } console.log(JSON.stringify(obj,["name","age","arr"]));
    // {"name":"过青年","age":20,"arr":[1,2,3,4]}
  • 如果过滤器参数是函数(过滤函数),可以改变序列化对象的结果;函数第一个参数默认是属性名(键),第二个参数默认是属性值

    如果返回的是undefined,则相应的属性名和属性值会被忽略

var jsonText = JSON.stringify(obj,function(key,value){
switch (key) {
case "name":
return 20;
case "age":
return "过青年";
case "arr":
return [4,3,2,1];
case "school":
return undefined;
default:
return value;
}
}); console.log(jsonText);
// {"name":20,"age":"过青年","arr":[4,3,2,1],"location":"江西宜春"}

(2)格式化:字符串缩进、空白符

第三个参数控制缩进和空白符

  • 如果是一个数值,表示空白字符个数,最大为10,大于10的转换成10;如果第三个参数是有效参数,会自动帮我们插入换行符,提高可读性;
var jsonText = JSON.stringify(obj,null,4);
console.log(jsonText);
/*
{
"name": "过青年",
"age": 20,
"arr": [
1,
2,
3,
4
],
"location": "江西宜春",
"school": {
"location": "江西南昌"
}
}
*/
  • 如果是一个字符串,这个字符串将被作为缩进字符,而非原来的空白字符作为缩进;字符串参数里的字符个数不能超过10个,超过10个,结果中只出现前十个字符;
var jsonText = JSON.stringify(obj,null,"-");
console.log(jsonText);
/*
{
-"name": "过青年",
-"age": 20,
-"arr": [
--1,
--2,
--3,
--4
-],
-"location": "江西宜春",
-"school": {
--"location": "江西南昌"
-}
}
*/

(3)toJSON方法

我们可以在需要序列化的对象上增加一个toJSON方法,这样当使用JSON.stringify()方法时,实际上就是调用了对象中的toJSON()方法

var obj = {
name: "过青年",
age: 20,
arr: [1,2,3,4],
location: "江西宜春",
school: {
location: "江西南昌"
},
toJSON:function(){
return this.name;
}
}
var jsonText = JSON.stringify(obj);
console.log(jsonText);
// 过青年

(4)把一个对象传入JSON.stringify()中,序列化该对象的顺序如下:

<1> 如果该对象中有toJSON方法,则直接调用该方法;

<2> 如果JSON.stringify()中有第二个参数,则应用过滤器,过滤器接受的值就是<1>中返回的值

<3> 过滤器处理<1>中返回的值

<4> 如果有第三个参数,执行相应的格式化

var obj = {
name: "过青年",
age: 20,
arr: [1,2,3,4],
location: "江西宜春",
school: {
"location": "江西南昌"
},
toJSON:function(){
name = this.name;
age = this.age;
return {name,age};
}
}
var jsonText = JSON.stringify(obj,function(key,value){
if(key === "name") {
return "哈哈哈";
}else{
return value;
}
});
console.log(jsonText); // {"name":"哈哈哈","age":20}

理解序列化对象的过程还是很重要的

1.31 解析选项

JSON.parse()方法也有两个参数,第二个参数是一个函数,叫做还原函数

var obj = {
name: "过青年",
age: 20,
arr: [1,2,3,4],
location: "江西宜春",
school: {
"location": "江西南昌"
}
};
var jsonText = JSON.stringify(obj);
var jsText = JSON.parse(jsonText,function(key,value){
if (key === "name") {
return "哈哈哈哈";
} else {
return value;
}
});
console.log(jsText);
//{name: '哈哈哈哈', age: 20, arr: Array(4), location: '江西宜春', school: {…}}

1.4 总结

  • JSON.stringify()用于序列化,JSON.parse()用于解析
  • JSON.stringify()有三个参数,第一个是js对象,第二个是过滤器,第三个是用来格式化JSON输出
  • JSON.parse()有两个参数,第一个参数是JSON对象,第二个参数是还原函数
  • js对象中可以声明一个toJSON方法,当JSON.stringify()方法调用时,自动执行toJSON方法
  • 注意,JSON.stringify()方法的返回值都是字符串类型

JSON基础使用详解的更多相关文章

  1. python 3.x 爬虫基础---Urllib详解

    python 3.x 爬虫基础 python 3.x 爬虫基础---http headers详解 python 3.x 爬虫基础---Urllib详解 前言 爬虫也了解了一段时间了希望在半个月的时间内 ...

  2. JWT基础概念详解

    JWT基础概念详解 JWT介绍 之前我们文章讲过分布式session如何存储,其中就讲到过Token.JWT.首先,我们来回顾一下使用Token进行身份认证. 客户端发送登录请求到服务器 服务器在用户 ...

  3. I2C 基础原理详解

    今天来学习下I2C通信~ I2C(Inter-Intergrated Circuit)指的是 IC(Intergrated Circuit)之间的(Inter) 通信方式.如上图所以有很多的周边设备都 ...

  4. RabbitMQ基础知识详解

    什么是MQ? MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.MQ是消费-生产者模型的一个典型的代表,一端往消息队列中不断写入消息,而另一端则可以读取队列中 ...

  5. Nmap扫描教程之基础扫描详解

    Nmap扫描教程之基础扫描详解 Nmap扫描基础扫描 当用户对Nmap工具了解后,即可使用该工具实施扫描.通过上一章的介绍,用户可知Nmap工具可以分别对主机.端口.版本.操作系统等实施扫描.但是,在 ...

  6. jmeter 基础功能详解

    jmeter 基础功能详解 thread group:包含一组线程,每个线程独立地执行测试计划. sampler:采样器,有多种不同的sample实现,用来发起各种请求,如http请求,jdbc请求, ...

  7. hadoop基础-SequenceFile详解

    hadoop基础-SequenceFile详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.SequenceFile简介 1>.什么是SequenceFile 序列文件 ...

  8. Cisco路由技术基础知识详解

    第一部分 请写出568A的线序(接触网络第一天就应该会的,只要你掐过,想都能想出来) .网卡MAC地址长度是(  )个二进制位(16进制与2进制的换算关系,只是换种方式问,不用你拿笔去算) A.12  ...

  9. RabbitMQ,Apache的ActiveMQ,阿里RocketMQ,Kafka,ZeroMQ,MetaMQ,Redis也可实现消息队列,RabbitMQ的应用场景以及基本原理介绍,RabbitMQ基础知识详解,RabbitMQ布曙

    消息队列及常见消息队列介绍 2017-10-10 09:35操作系统/客户端/人脸识别 一.消息队列(MQ)概述 消息队列(Message Queue),是分布式系统中重要的组件,其通用的使用场景可以 ...

随机推荐

  1. group by <grouping sets(...) ><cube(...)>

    GROUP BY      GROUPING SETS() 后面将还会写学习 with cube,  with rollup,以及将它们转换为标准的GROUP BY的子句GROUP SET(), CU ...

  2. 商城08——activeMQ 使用消息队列同步索引库

    1.  课程计划 1.什么是MQ 2.MQ的应用场景 3.ActiveMQ的使用方法. 4.使用消息队列实现商品同步. 2.  同步索引库分析 方案一:在taotao-manager中,添加商品的业务 ...

  3. 找到了两个联想的OEM XP镜像文件

    今天在收拾移动硬盘的时候发现了两个XP镜像 还都是联想的,一个有OOBE,另一个无OOBE,全传网盘里了,需要的自取 有个疑问 2020年还有多少家庭电脑和ATM机器还在用XP??? link:htt ...

  4. Vmware的各版本KEY

    算是之前收集到的备份一下在这里吧,顺便方便别人(ô‿ô) 应该是比较全的 VMware Workstation4.xx for WindowsZHDH1-UR90N-W844G-4PTN6G1NP0- ...

  5. 使用SpringCloud Stream结合rabbitMQ实现消息消费失败重发机制

    前言:实际项目中经常遇到消息消费失败了,要进行消息的重发.比如支付消息消费失败后,要分不同时间段进行N次的消息重发提醒. 本文模拟场景 当金额少于100时,消息消费成功 当金额大于100,小于200时 ...

  6. 磨皮美颜算法 附完整C代码

    前言 2017年底时候写了这篇<集 降噪 美颜 虚化 增强 为一体的极速图像润色算法 附Demo程序> 这也算是学习过程中比较有成就感的一个算法. 自2015年做算法开始到今天,还有个把月 ...

  7. for, for in, for of, map, forEach 循环的区别:

    for, for in,  for of, map, forEach 循环的区别: for  遍历数组: //对象遍历数组 var arr = [ {Monday: '星期一', Tuesday: ' ...

  8. VMware Workstation 15密钥

    在打开的VMware Workstation 15输入许可证密钥对话框里直接输入25位密钥,然后点击确定,如下图所示. 这里提供一个密钥: CG392-4PX5J-H816Z-HYZNG-PQRG2

  9. springboot 2.X 集成redis

    在实际开发中,经常会引入redis中间件做缓存,这里介绍springboot2.X后如何配置redis 1 Maven中引入redis springboot官方通过spring-boot-autoco ...

  10. SpringCloud 入门(三)

    前文我们介绍了简单的创建一个客户端,并介绍了它是如何提供服务的,接下来介绍它的另外一个组件:zuul. zuul 提供了微服务的网关功能,通过它提供的接口,可以转发不同的服务,可以当作一个中转站. 搭 ...