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 中的函数在序列化与反序列化的时候会被忽略等等其他的规则。

相关推荐
卡拉叽里呱啦10 分钟前
缓存-变更事件捕捉、更新策略、本地缓存和热key问题
分布式·后端·缓存
David爱编程15 分钟前
线程调度策略详解:时间片轮转 vs 优先级机制,面试常考!
java·后端
张人玉19 分钟前
XML 序列化与操作详解笔记
xml·前端·笔记
杨荧27 分钟前
基于Python的宠物服务管理系统 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python·信息可视化
码事漫谈1 小时前
C++继承中的虚函数机制:从单继承到多继承的深度解析
后端
阿冲Runner1 小时前
创建一个生产可用的线程池
java·后端
YeeWang1 小时前
🎉 Eficy 让你的 Cherry Studio 直接生成可预览的 React 页面
前端·javascript
gnip1 小时前
Jenkins部署前端项目实战方案
前端·javascript·架构
写bug写bug1 小时前
你真的会用枚举吗
java·后端·设计模式
Orange3015111 小时前
《深入源码理解webpack构建流程》
前端·javascript·webpack·typescript·node.js·es6