博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js - object.assign 以及浅、深拷贝
阅读量:5889 次
发布时间:2019-06-19

本文共 1219 字,大约阅读时间需要 4 分钟。

浅(引用)拷贝:共用同一内存地址,你改值我也变

譬如常用的对象赋值操作

 

深拷贝:深拷贝即创建新的内存地址保存值(互不影响)

譬如以下

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之间相同的属性是直接覆盖的,如果属性值为对象,是不会对对象之间的属性进行合并

 

对象深拷贝可以利用第三方:实现

 

 

数组的浅、深拷贝也是如此!

 

 

 

 

 

 

详情可以看,文章转载于:

 

你可能感兴趣的文章
配置tomcat启动时的优化参数
查看>>
Windows2003服务器DHCP CLINET无法启动处理
查看>>
skyline 简单的Vbscript代码示意
查看>>
内存分页
查看>>
python切片详解
查看>>
go 语言操作数据库-redis,restful
查看>>
spring bean的几种初始化方法和销毁方法的先后顺序
查看>>
idea新建springCloud项目(4)- 商品服务
查看>>
Android之ListView原理学习与优化总结
查看>>
Java Study_String
查看>>
JD-Eclipse的插件安装class反编译
查看>>
医疗工具_会诊IM app展示
查看>>
Qunee for HTML5与ECharts对比
查看>>
《Nginx高性能Web服务器》系列分享专栏
查看>>
zendframework 修改默认路由配置
查看>>
监听系统网络状态
查看>>
需要多个参数的对象的实例化
查看>>
win2008 域安全策略管理
查看>>
Android DownloadManager ERROR_UNKNOWN 在API 17 巨坑完美解决
查看>>
Spark学习脑图
查看>>