ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Object.assign实现的是浅拷贝还是深拷贝?

2022-08-25 12:00:10  阅读:216  来源: 互联网

标签:console log Object 拷贝 assign target


首先MDN官网中有一句写道:

 

 

 

assign()语法:

Object.assign(target, ...sources)
target:目标对象,接收源对象属性的对象,也是修改后的返回值。
sources:源对象,包含将被合并的属性。

下面来看例子:
 let s = { a: 1 }
      let target = Object.assign({}, s)
      console.log(target) // { a: 1 }

      s.a = 2
      console.log(s) // { a: 2 }
      console.log(target) // { a: 1 }

看到这里可能有人会说,这不是第一层就是深拷贝吗?其实非如此



let s = { a: { b: 1 }, c: 1 }
      let target = Object.assign({}, s)
      console.log(target) // { a: { b: 1 }, c: 1 }

      s.a.b = 2
      s.c = 3
      console.log(s) // { a: { b: 2 }, c: 3 }
      console.log(target) // { a: { b: 2 }, c: 1 }

target.a.b的值随着source变化而变化,但是target.c的值并没有随着source变化

 

下面来总结开篇提到的:针对使用深拷贝,需要使用其他方法,因为

Object.assign()拷贝的是属性值,如果源对象的属性值是一个指向对象的指针,那也只拷贝那个指针。

所以如果对象的属性值为基础类型,通过Object.assign()拷贝的那个属性而言是深拷贝。

如果对象的属性值为引用类型,通过Object.assign()拷贝的那个属性而言是浅拷贝。




 

标签:console,log,Object,拷贝,assign,target
来源: https://www.cnblogs.com/Ynline/p/16623853.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有