JSON.stringify/parse有什么缺点?

JSON 在 JavaScript 中是最为常见的 API 通常用 HTTP 获取 JSON 数据,简单类型数据结构深拷贝等等。这篇文章主要讲解 JSON 的API 和其主要的缺点,以及 JSON5 部分内容。

一、JSON 支持的数据类型

  • 🥇String: 双引号
  • 🥇Number: 整数和浮点型
  • 🥇Boolean: 布尔值
  • 🥇Array:数组
  • 🥇Object: 对象
  • 🥇Null: 空值

二、JSON API

ts 复制代码
JSON.parse(text)
JSON.parse(text, reviver)

JSON.stringify(value[, replacer [, space]])

JSON API 可以被用作深拷贝,但是也有很多的缺点。下面会说明 JSON 的缺点:

三、JSON 的缺点

  • 🥇不能序列化:函数(如果是函数,直接忽略这属性)
  • 🥇无法处理循环引用
  • 🥇限制数据类型,不支持的有
    • 💕RegExp: 结果: 字符串
    • 💕Map: 错误结果:
      • 💨传递不可迭代的对象: xxx is not iterable (cannot read property Symbol(Symbol.iterator))
      • 💨传递可迭代对象(嵌套页需要可迭代):序列化之后是 {}
    • 💕Set
      • 💨可迭代对象:序列化后空对象: {}
      • 💨不得迭代对象:XXX is not iterable (cannot read property Symbol(Symbol.iterator))
    • ...
  • 🥇无法处理某些特殊的值(会被转换成 null)
    • 💕undefined: 字段亏被直接 忽略
    • 💕Symbol: 字段亏被直接 忽略

基本示例

ts 复制代码
let json = {
  date: new Date(),
  b: new Date("1992-05-15"),
  c: function () {},
  r: new RegExp("\\d+"),
  // m: new Map({}), //  object is not iterable (cannot read property Symbol(Symbol.iterator))
  // s: new Set(1) //  object is not iterable (cannot read property Symbol(Symbol.iterator))
  s: Symbol(),
  u: undefined,
};

console.log(JSON.stringify(json));

循环引用

ts 复制代码
// 创建循环引用的对象
const objA = {};
const objB = { a: objA };
objA.b = objB;

// 尝试序列化包含循环引用的对象
try {
  const jsonString = JSON.stringify(objA);
  console.log(jsonString); // 这行代码不会执行,因为在序列化时会抛出错误
} catch (error) {
  console.error('Error:', error.message); // 捕获到错误并打印错误信息
}

在 node.js 中会包出如下的循环引用的错误:

ts 复制代码
Error: Converting circular structure to JSON
    --> starting at object with constructor 'Object'
    |     property 'b' -> object with constructor 'Object'
    --- property 'a' closes the circle

四、JSON5支持的数据类型

  • 🥇多行字符串
  • 🥇注释
  • 🥇数据类型
    • 💕Infinity/-Infinity
    • 💕NaN
    • 💕undefined
  • 🥇末尾逗号
  • 🥇可以省略对象和数组的大括号与方括号
  • 🥇没有使用引号的属性名和字符串

五、认识并 JSON5

💛 json5.org/ json5 的全部

使用 JSON5

ts 复制代码
npm install json5

JSON5 语法

ts 复制代码
JSON5.parse(text[, reviver])

// api
JSON5.stringify(value[, replacer[, space]])
JSON5.stringify(value[, options])

// cli
json5 [options] <file>

六、小结

本文主要讲解 JSON 相关的 API,和 JSON 的缺点。JSON 中的函数在序列化与反序列化的时候会被忽略等等其他的规则。

相关推荐
蜡台4 分钟前
Vue 打包优化
前端·javascript·vue.js·vite·vue-cli
木斯佳4 分钟前
前端八股文面经大全:快手前端一面 (2026-03-29)·面经深度解析
前端·宏任务·原型链·闭包
johnrui18 分钟前
SpringBoot-JdbcTemplate
java·spring boot·后端
皙然19 分钟前
Redis配置文件(redis.conf)超详细详解
前端·redis·bootstrap
卷帘依旧43 分钟前
JavaScript中this绑定问题详解
前端·javascript
dweizhao1 小时前
突发!Claude Code源码泄露了
前端
Victor3561 小时前
MongoDB(72)如何创建用户和角色?
后端
Victor3561 小时前
MongoDB(71)如何启用MongoDB身份验证?
后端
想打游戏的程序猿1 小时前
工具与协议层——Agent 如何连接世界
后端·ai编程
希望永不加班2 小时前
SpringBoot 过滤器(Filter)与请求链路梳理
java·spring boot·后端·spring