什么是JSON
{
"name": "小徐",
"experience": 2.5,
"hobbit": ["唱歌","跳舞","打球","说唱"]
}
什么是Object
var o = {
name: '小吴',
age: 22,
height: 185
}
为什么会被混为一谈
原因很简单:这两个东西长得很像啊,都有花括号/键值对,而且JSON就是由JavaScript衍生出来的格式,难免会傻傻分不清楚
然而作为一个较真的切图仔,不能这么马马虎虎地对待这方面的知识。我们把Object写成这样:
const o = {
name: '小吴',
age: Math.floor(Math.random()*10) + 20,
height: 3*60+5,
// 每涨一岁,就skr一次
[Symbol.iterator]: function* () {
let count = 0;
while (count < this.age) {
yield 'skr'
count += 1;
}
},
}
这时候,你还会认为他是JSON吗?(JSON: 打扰了,告辞)
认祖归宗
Object是JavaScript中的键值对数据格式,与之同类的应该是Python中的字典、Golang中的map、Lua中的Table等基于键值对的数据结构
而JSON
本质是数据格式(不是数据结构),他的同类应该是xml
、yaml
等用做存储和传输的数据格式。
Object包含了JSON,你可以使用JSON表示JavaScript的Object,但不能把应为Object长得像JSON(实际上是JSON像Object)而将两者混为一谈
拓展
当然JavaScript的Object有不同的写法,上面的Object可以这么写:
var o = new Object();
o.name = '小吴'
o.age = Math.floor(Math.random()*10) + 20
// ...
这种写法和前者“花括号”定义对象的方式是等价的,我们重点说前者,也就是花括号的那种写法,有它自己的名字:
对象字面量
字面量(literal)简单来说就是表示某种数据结构文本格式。打个比方,你想让JavaScript创建一个字符串,你需要输入"hello word"
,花括号的内容就是字符串字面量
。同理[1, 2, 3]
就是数组字面量
,而{a:1, b:2}
,就是我们的主角:对象字面量。字面量的使用,能令我们的语言表达力更加直观和丰富,代码可读性更高。如果缺少某些类型的字面量(以缺少数组和对象字面量举例),你的代码可能就会变成这样子:
var list = new Array()
for (var i = 0; i < 3; i++) {
var descriptor = new Object()
descriptror.value = i + 1;
Object.defineProperty(list, i.toString(), descriptor)
}
对象字面量 vs. JSON
对象字面量 | JSON | |
---|---|---|
定义 | JavaScript中定义对象的一种格式 | 通用的轻量级数据交换格式 |
作用 | 定义一个JavaScript对象 | 将数据以键值对的形式读取、保存与传输 |
共同点 | 基于键值对、使用花括号{} 包裹 |
|
数据类型 |
key 为字符串,value 接受所有JavaScript类型数据或者表达式 |
key 为字符串,value 可接受数字 、字符串 、数组 、布尔值 、null 和嵌套的JSON
|
书写格式 | key直接写,也可以使用单引号'' 、双引号"" 包裹,允许尾部添加逗号 |
key和字符串value ,必须使用双引号"" 包裹, 其余value与JavaScript类型格式一致,不允许尾逗号 |
转换 | 对象转JSON:JSON.stringify
|
JSON转对象:JSON.parse
|