有关JSON的知识点整理
参考资料:《JavaScript高级程序设计》
1. 关于JSON
JSON是JavaScript的一个严格的子集,利用了JavaScript中的一些模式来表示结构化数据。
JSON是一种数据结构,而不是一个编程语言。虽然它与JavaScript具有相同的语法形式,但JSON并不从属于JavaScript。
因为它只是一种数据结构,所以很多编程语言都可以使用它。
2. 语法
JSON的语法可以表示下面三种类型的值:
- 简单值:
使用与JavaScript相同的语法,可以在JSON中表示字符串、数值、布尔值和null。但是JSON不支持JavaScript中的特殊值undefined。- 对象:
对象作为一种复杂的数据类型,表示的一组有序的键值对。而每个键值对中的值可以是简单值,也可以是复杂数据类型的值。- 数组:
数组也是一种复杂数据类型,表示一组有序的值得列表。可以通过数值的索引来访问其中的值。
JSON不支持变量、函数或对象实例。
2.1 简单值
最简单的JSON数据形式就是简单值。
5
上面的数值5就是有效的JSON数据。
''hello, beijing''
上面的字符串也是有效的JSON数据。(必须用双引号)
2.2 对象
下面的是一个JavaScript中定义的对象字面量:
let people = {
name: '小明',
age: 12
};
在JSON中,上面的对象的写法为:
{
"name": "小明",
"age": 12
}
二者对比,区别在于:
- JSON对象没有声明变量。
- 变量名必须使用双引号。
2.3 数组
JSON数组采用的就是JavaScript中的数组字面量形式。
下面的是JavaScript中的数组:
var arr = [12, 'hi', true]
在JSON中,表达为:
[25, "hi", true]
同样,JSON数组也没有变量和分好。
3. 解析与序列化
与XML相比较,JSON更容易解析为有用的JavaScript对象。
早期的JSON解析器基本上就是使用JavaScript的eval()函数。由于JSON是JavaScript语法的子集,所以eval()函数可以解析、解释并返回JavaScript对象和数组。
JSON对象有两个方法:stringify()
和parse()
。
这两个方法分别用于把JavaScript对象序列化为JSON字符串和把JSON字符串解析为原生的JavaScript值。
例如:
let book = {
title: 'javaScript',
authors: 'wg',
edition: 3
}
let jsonText = JSON.stringify(book)
打印jsonText的值为:
"{"title":"javaScript","authors":"wg","edition":3}"
在序列化JavaScript对象时,所有函数和原型成员都会被有意忽略。
此外,值为undefined的任何属性也都会被跳过。
把JSON字符串直接传递给JSON.parse()就可以得到相应的JavaScript值。
例如:
let bookCopy = JSON.parse(jsonText)
注意,虽然book与bookCopy具有相同的属性,但它们是两个独立的,没有任何关系的对象。
JSON.stringify()除了要序列化的JavaScript对象外,还可以接手另外两个参数。这两个参数用于指定以不同的方式序列化JavaScript对象。
第一个参数是个过滤器,可以是一个数组,也可以是一个函数。
第二个参数是一个选项,表示是否在JSON字符串中保留缩进。
完。
转载于:https://www.jianshu.com/p/d427f5b1c164
下一篇: 一道有关闭包和变量提升的前端面试题