js - object.assign 以及浅、深拷贝

浅(引用)拷贝:共用同一内存地址,你改值我也变
深拷贝:深拷贝即创建新的内存地址保存值(互不影响)

譬如以下

const shallBasicCopy = obj => {
  JSON.parse(JSON.stringify(obj))
}
  • 优点:能正确处理的对象只有Number、String、Array等能够被json表示的数据结构
  • 缺点:函数这种不能被json表示的类型将不能被正确处理

关于object.assign的梗(对象深、浅拷贝)

有些人说深拷贝,有些人说浅拷贝,也不见的谁错或对(某些特定情况下)

// 深拷贝
let srcObj = {
 'name': 'lilei',
 'age': '20'
};

let copyObj2 = Object.assign({}, srcObj, {
 'age': '21'
});

copyObj2.age = '23';

console.log('srcObj', srcObj); //{ name: 'lilei', age: '22' }


// 浅拷贝
srcObj = {
 'name': '明',
 grade: {
   'chi': '50',
   'eng': '50'
 }
};
copyObj2 = Object.assign({}, srcObj);
copyObj2.name = '红';
copyObj2.grade.chi = '60';
console.log('新 objec srcObj', srcObj); // { name: '明', grade: { chi: '60', eng: '50' } }

梗就在这里:

从例子中可以看出,改变复制对象的name 和 grade.chi ,源对象的name没有变化,但是grade.chi却被改变了。因此我们可以看出Object.assign()拷贝的只是属性值,假如源对象的属性值是一个指向对象的引用,它也只拷贝那个引用值。
也就是说,对于Object.assign()而言, 如果对象的属性值为简单类型(string, number),通过Object.assign({},srcObj);得到的新对象为‘深拷贝’;如果属性值为对象或其它引用类型,那对于这个对象而言其实是浅拷贝的。这是Object.assign()特别值得注意的地方。
多说一句,Object.assign({}, src1, src2); 对于scr1和src2之间相同的属性是直接覆盖的,如果属性值为对象,是不会对对象之间的属性进行合并的

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 人与人之间的差别比我们想象的大得多。 我们应该意识到人与人之间是非常不同的,我们这个时代,应该是一个强调个性化的时...
    商学人阅读 1,756评论 0 0
  • 你经过了我 可以是走进了我的视线 又或是阻挡了我欣赏美景的眼 我可以是 视而不见 也可是以是 如影随形 ...
    流浪诗人在流浪阅读 1,085评论 0 0
  • 早上在霍营站排队等地铁的时候,旁边来了位穿着白色T恤和白色小短裙的姑娘。就暂且叫她白姑娘吧。但令人奇怪的是,她在原...
    老祝读书阅读 1,895评论 0 0

友情链接更多精彩内容