JSON是轻量级文本交换格式,非JavaScript对象或类,仅含parse()和stringify()两个静态方法;parse()严格校验标准JSON语法,stringify()忽略函数/undefined/Symbol/循环引用,且fetch的.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)返回null;JSON.parse("null")也返回null;但JSON.parse("")报错
用 JSON.stringify() 序列化时,会忽略函数、undefined、Symbol 和循环引用
JSON.stringify() 只能处理可序列化的值。它不是“深拷贝”工具,也不保留原型链或特殊类型语义。
家电公司网站源码是一个以米拓为核心进行开发的家电商城网站模板,程序采用metinfo5.3.9 UTF8进行编码,软件包含完整栏目与数据。安装方法:解压上传到空间,访问域名进行安装,安装好后,到后台-安全与效率-数据备份还原,恢复好数据后到设置-基本信息和外观-电脑把网站名称什么的改为自己的即可。默认后台账号:admin 密码:132456注意:如本地测试中127.0.0.1无法正常使用,请换成l
- 被静默丢弃的字段:
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() 就会失败。
立即学习“Java免费学习笔记(深入)”;
- ✅ 正确顺序(二选一):
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









