使用JSON实现数据深拷贝时需要注意的坑

JSON实现深拷贝非常便利,但如果你不熟悉JSON或者对将要被深拷贝的对象不清楚,那么的话,还是要谨慎些。

// JSON深拷贝
JSON.parse(JSON.stringify(obj));

 

存在以下几种情况,被拷贝对象会出现异常:

1. 如果存在循环引用,使用JSON进行拷贝时会直接报错;

// Error
var o = {
  x: null,
};
o.x = o;

2. Map, Set, WeakMap, WeakSet数据会被转为普通的Object;

复制代码
var o = {
  m: new Map(),
  n: new Set(),
  wm: new WeakMap(),
  wn: new WeakSet(),
};

JSON.parse(JSON.stringify(o));

// output:
//{
//    m: {},
//    n: {},
//    wm: {},
//    wn: {},
//}
复制代码

3. Date对象会被转为String对象;

var s = {
  d: new Date(),
};

var cp = JSON.parse(JSON.stringify(s));
// output: {d: Sat Nov 26 2022 23:33:13 GMT+0800 (中国标准时间)}

4. NaN, Infinity, -Infinity 会被转为null

复制代码
var o = {
  n: NaN,
  i: Infinity,
  di: -Infinity,
};

JSON.parse(JSON.stringify(o));

// output:
//{
//   di: null,
//   i: null,
//   n: null,
//}
复制代码

5. 当属性值为Function, Undefined, Symbol时,会被直接抹掉

复制代码
var o = {
  und: undefined,
  fn: () => {},
  sy: Symbol('sy'),
};

JSON.parse(JSON.stringify(o));

// output:
// {}
复制代码

 

posted @   樊顺  阅读(608)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?
点击右上角即可分享
微信分享提示