Object.assign() 深拷贝和浅拷贝的问题

图片描述

如上图,据描述,Object.assign()为浅拷贝, 为什么改变属性a不是指向同一个引用,而b.c指向了同一个引用?

阅读 19.3k
4 个回答
var deepCopy = function(src) {
    var ret = {}
    for (var k in src) {
        ret[k] = typeof src[k] ==='object' ? deepCopy(src[k]) : src[k]
    }
    return ret
}

深拷贝一直用这个方法, Object.assgin 只能深拷贝第一层, 深层的还是浅拷贝, 记住这个就行了

新手上路,请多包涵

mdn 讲述 assign 的时候, 有举和题主问题完全一样的例子
这里是文章链接

原因就是 (摘抄自 MDN )
因为 Object.assign()拷贝的是属性值。假如源对象的属性值是一个指向对象的引用,它也只拷贝那个引用值

新手上路,请多包涵
let obj3 = Object.assign({},obj1,{b:Object.assign({},obj1.b)});

let obj4 = JSON.parse(JSON.stringify(obj1));

浅拷贝:如果属性元素为复杂杂数据类型时,内层元素拷贝引用;
slice, concat, jQury$.extend({},obj)都是浅拷贝;
点击这里了解详情

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题