美文网首页
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中实现深度拷贝,复制一个对象

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