JS原生的深拷贝API structuredClone函数简介

💡 原文中文,约4000字,阅读约需10分钟。
📝

内容提要

本文介绍了JavaScript中的深度克隆方法structuredClone(),其用法简单,支持循环引用,能更好地处理复杂对象(如Date、Set等),相比于JSON方法更具优势。但它无法复制DOM对象和getter/setter,建议在不支持的环境中使用Polyfill。

🎯

关键要点

  • Web浏览器提供了原生的深度克隆方法structuredClone(),使用简单。
  • structuredClone()支持循环引用,能更好地处理复杂对象,如Date、Set等。
  • structuredClone()的语法为structuredClone(value, options),options支持transfer参数。
  • transfer参数可用于大数据传输,节约内存开销。
  • structuredClone()在所有常见浏览器中兼容性良好,但建议在不支持的环境中使用Polyfill。
  • 使用JSON.parse(JSON.stringify(obj))进行深度拷贝时可能会出现问题,例如Date对象会变为字符串。
  • structuredClone()能够正确处理Date、Set、Map等复杂对象。
  • 使用扩展运算符或Object.assign()等方法进行深拷贝时,若对象属性值也是对象,会导致原对象被修改。
  • structuredClone()不能复制DOM对象、函数、属性描述符、setter和getter。
  • 克隆的对象原型链不会被复制,克隆的实例将不再是原类的实例。
➡️

继续阅读