【JavaScript】请不要把Object和JSON混为一谈

栏目: IT技术 · 发布时间: 4年前

内容简介:原因很简单:然而作为一个较真的切图仔,不能这么马马虎虎地对待这方面的知识。我们把Object写成这样:这时候,你还会认为他是JSON吗?(JSON: 打扰了,告辞)

什么是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 本质是 数据格式 (不是数据结构),他的同类应该是 xmlyaml 等用做存储和传输的数据格式。

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

失控的未来

失控的未来

[美]约翰·C·黑文斯 / 仝琳 / 中信出版集团 / 2017-4-1 / 59.00元

【编辑推荐】 20年前,尼古拉•尼葛洛庞帝的《数字化生存》描绘了数字科技给人们的工作、生活、教育和娱乐带来的冲击和各种值得思考的问题。数字化生存是一种社会生存状态,即以数字化形式显现的存在状态。20年后,本书以一种畅想的形式,展望了未来智能机器人与人类工作、生活紧密相联的场景。作者尤其对智能机器人与人类的关系,通过假设的场景进行了大胆有趣的描述,提出了人工智能的未来可能会面临的一些问题。黑文......一起来看看 《失控的未来》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

URL 编码/解码
URL 编码/解码

URL 编码/解码