美文网首页
JS中实现深度拷贝,复制一个对象

JS中实现深度拷贝,复制一个对象

作者: 前端里程 | 来源:发表于2019-04-18 11:23 被阅读0次

在JS中拷贝、复制一个对象的方式有多种,我常用的一般是 Object.assign({},sourceObj)。
Object.assign()因为 Object.assign()拷贝的是属性值。假如源对象的属性值是一个对象的引用,那么它也只指向那个引用。如果合并的对象是多层嵌套对象那就属于浅拷贝了,修改内层对象的值还是会影响原对象。
要想实现深度复制可以使用JSON方式。
写法如下:

let newObj = JSON.parse(JSON.stringify(sourceObj))//深度复制对象

它的原理是把JS对象转换为JSON字符串,再由JSON字符串转换为JS对象,这样新对象的指针就不会指向原对象的指针了。但这种也有副作用的,有一下几点副作用:
1、有属性包含时间对象,拷贝后就是字符串的形式。
2、有函数或undefined,拷贝后会丢失。
3、有RegExp和Error对象,拷贝后变为空对象。
4、存在循环引用的情况,没法正确拷贝。
5、内层对象是构造函数生成的,会丢失constructor。
6、属性值为NaN、Infinity,拷贝后变为null。

虽然有些副作用,但大多情况还是符合要求可以使用。

相关文章

  • js对象深度拷贝

    js对象为什么要深度拷贝,不深度拷贝有什么影响? 举个例子 将对象通过 “ = ”复制给另一个对象时,只是相对于给...

  • JS中实现深度拷贝,复制一个对象

    在JS中拷贝、复制一个对象的方式有多种,我常用的一般是 Object.assign({},sourceObj)。O...

  • javascript 数组以及对象的深拷贝

    数组的深拷贝在js中,数组和对象的复制如果使用=号来进行复制,那只是浅拷贝。如下图演示: for 循环实现数组的深...

  • JS中数组和对象的 深复制(拷贝)与浅复制(拷贝)

    JS中数组和对象的 深复制(拷贝)与浅复制(拷贝) 1.js中有五种简单的数据类型(null,string,und...

  • JavaScript中拷贝对象方法总结

    对象拷贝是在js中最基本的对象操作。 浅拷贝 浅复制仅仅复制嵌套对象的地址: 拷贝需要注意的问题有很多: 需要拷贝...

  • JS实现对象深度拷贝

  • Python 相关

    Python copy以及其中的deepcopy可以拷贝python类对象,深度复制,对于想快速复制对象中的变量特...

  • UI(十五)深浅拷贝

    拷贝:复制一个对象->变成另外一个对象 深拷贝:复制对象 并且复制对象里面的内容 完全拷贝 浅拷贝:指针拷贝 只拷...

  • JS中对象的复制

    JS中的对象复制分为两种情况:深拷贝和浅拷贝。深拷贝和浅拷贝的区别在于对数组和对象的拷贝,对它们拷贝时浅拷贝只是拷...

  • 手写实现深度拷贝

    手写实现深度拷贝 本文参考:面试题之如何实现一个深拷贝 基础理论 拷贝的基础是赋值,在 js 中,将一个变量赋值给...

网友评论

      本文标题:JS中实现深度拷贝,复制一个对象

      本文链接:https://www.haomeiwen.com/subject/beezwqtx.html