登录
首页 >  文章 >  前端

JSON是什么及如何解析序列化数据

时间:2026-04-23 21:10:39 301浏览 收藏

JSON是一种轻量级、与语言无关的文本数据交换格式,它并非JavaScript对象或类,而是仅提供parse()和stringify()两个严格遵循标准的静态方法的内置全局对象;parse()对输入语法零容忍,任何非标准写法(如单引号、尾随逗号、undefined值)都会报错,而stringify()则会静默忽略函数、undefined、Symbol及循环引用,并对日期等特殊类型做预设转换;尤其需警惕fetch中.json()方法的不可重复调用特性——一旦响应体被读取(如先调用text()),再次调用.json()将失败。理解JSON的纯粹性与边界,是避免常见解析陷阱、写出健壮前后端通信代码的关键。

javascript中的JSON是什么_如何解析和序列化数据

JSON 是 JavaScript 的内置数据格式,不是对象也不是类

JSON(JavaScript Object Notation)本质上是一种轻量级的文本数据交换格式,它**不是 JavaScript 的某种对象类型**,也不需要 new 或构造函数。浏览器和 Node.js 环境中直接提供 JSON 这个全局对象,它只有两个静态方法:JSON.parse()JSON.stringify()。你不能对 JSON 实例化,也不能给它添加属性或方法。

用 JSON.parse() 解析字符串时,必须确保输入是合法 JSON 格式

JSON.parse() 严格校验语法,哪怕多一个逗号、少一对引号、用了单引号、写了注释或包含 undefined / function,都会抛出 SyntaxError。它不接受 JavaScript 字面量语法,只认标准 JSON。

  • ✅ 合法:
    JSON.parse('{"name": "Alice", "age": 30}')
  • ❌ 非法(单引号):
    JSON.parse("{'name': 'Alice'}")
  • ❌ 非法(尾随逗号):
    JSON.parse('{"name": "Alice",}') 
  • ❌ 非法(undefined 值):
    JSON.parse('{"value": undefined}')
  • ⚠️ 注意:JSON.parse(null) 返回 nullJSON.parse("null") 也返回 null;但 JSON.parse("") 报错

用 JSON.stringify() 序列化时,会忽略函数、undefined、Symbol 和循环引用

JSON.stringify() 只能处理可序列化的值。它不是“深拷贝”工具,也不保留原型链或特殊类型语义。

  • 被静默丢弃的字段:
    JSON.stringify({ a: 1, b: undefined, c: () => {}, d: Symbol('x') }) // → '{"a":1}'
  • 循环引用直接报错:
    const obj = {}; obj.self = obj; JSON.stringify(obj) // → TypeError: Converting circular structure to JSON
  • 日期对象转为 ISO 字符串:
    JSON.stringify({ t: new Date(2023, 0, 1) }) // → '{"t":"2023-01-01T00:00:00.000Z"}'
  • 可传入 replacer 函数或数组定制输出,比如过滤字段或转换值

和服务端通信时,别混淆 fetch 的 body 和 JSON 解析步骤

常见误区是以为 fetch(url).then(res => res.json()) 中的 .json() 是调用 JSON.parse() —— 实际上它是 Response 对象的方法,内部做了流读取和解析,且**只能调用一次**。如果先读了 res.text(),再调用 res.json() 就会失败。

  • ✅ 正确顺序(二选一):
    fetch('/api').then(r => r.json())
    fetch('/api').then(r => r.text()).then(txt => JSON.parse(txt))
  • ❌ 错误:
    fetch('/api').then(r => r.text()).then(txt => { console.log(txt); return r.json(); }) // r.body 已被读取
  • 注意:响应体不是 JSON?比如返回纯文本或 HTML,r.json() 会拒绝 promise 并抛出 SyntaxError
JSON 的边界很清晰:它只是字符串 ↔️ JS 值的单向翻译器,不负责类型还原、不处理副作用、不兼容 JS 特有语法。真正容易出问题的地方,往往在「以为它更聪明」的时候。

到这里,我们也就讲完了《JSON是什么及如何解析序列化数据》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>