JavaScript 深拷贝方法介绍

发布于 2024-02-13 19:18:04 字数 1501 浏览 23 评论 0

1. JSON.stringify

缺点

  • 无法处理时间对象,会将时间对象形式转化为字符串形式
var test = {
    name: 'a',
    date: [new Date(1536627600000), new Date(1540047600000)], // 对象
  }

  let b;
  b = JSON.parse(JSON.stringify(test))
console.log(b) // {date: (2) ["2018-09-11T01:00:00.000Z", "2018-10-20T15:00:00.000Z"], name: "a"}
  • 无法转换正则表达式
  • 无法转换函数、undefined,会丢失这个属性
  • 如果 obj 里有 NaN、Infinity 和-Infinity,则序列化的结果会变成 null
  • 只能序列化对象的可枚举的自有属性
  • 如果对象中存在循环引用的情况也无法正确实现深拷贝

2. 递归实现深拷贝

function deepClone(obj, hash = new WeakMap()) {
  if (obj === null) return obj; // 如果是 null 或者 undefined 我就不进行拷贝操作
  if (obj instanceof Date) return new Date(obj);
  if (obj instanceof RegExp) return new RegExp(obj);
  // 可能是对象或者普通的值  如果是函数的话是不需要深拷贝
  if (typeof obj !== "object") return obj;
  // 是对象的话就要进行深拷贝
  if (hash.get(obj)) return hash.get(obj); // weakmap 存储对象会产生一个新的引用,所以修改原对象不会影响到 weakmap
  let cloneObj = new obj.constructor();
  // 找到的是所属类原型上的 constructor,而原型上的 constructor 指向的是当前类本身
  hash.set(obj, cloneObj);
  for (let key in obj) {
    if (obj.hasOwnProperty(key)) {
      // 实现一个递归拷贝
      cloneObj[key] = deepClone(obj[key], hash);
    }
  }
  return cloneObj;
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

別甾虛僞

暂无简介

0 文章
0 评论
23 人气
更多

推荐作者

我们的影子

文章 0 评论 0

素年丶

文章 0 评论 0

南笙

文章 0 评论 0

18215568913

文章 0 评论 0

qq_xk7Ean

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文