Object.assign详解

一、Object.assign是什么?

  首先了解下Object.assign()是什么。我们先看看ES6官方文档是怎么介绍的?

  Object.assign() 方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。当时用下面的方法控制它不可枚举之后,我们就无法进行拷贝了:    
  Object.defineProperty(a, 'x', {
  value: 'xxx',
  enumerable: false//该属性不可枚举
 })

  简单来说,就是Object.assign()是对象的静态方法,可以用来复制对象的可枚举属性到目标对象,利用这个特性可以实现对象属性的合并。

二、用法:

  Object.assign(target, ...sources)
  //第一个参数永远为目标对象,后面的都是源对象

参数:target—>目标对象

  source--->源对象

返回值:target,即目标对象

三、使用示例:

1、目标对象和源对象无重名属性

var target={name:‘guxin’,age:18};
var source={state:‘single’}
var result=Object.assign(target,source);
console.log(target,target==result);
结果如图:
在这里插入图片描述

我们可以看到source上的state属性合并到了target对象上。如果只是想将两个或多个对象的属性合并到一起,不改变原有对象的属性,可以用一个空的对象作为target对象。像下面这样:

var result=Object.assign({},target,source);
2、目标对象和源对象有重名属性

上面的示例目标对象和源对象是没有重名属性的,那么如果他们有重名属性又会怎样呢?是后面的属性覆盖前面的还是前面的属性覆盖后面的呢?我们接下来看下一个例子:

var target={name:‘guxin’,age:18}
var source={state:‘signle’,age:22}
var result=Object.assign(target,source)
console.log(target)
我们来看下运行结果:
在这里插入图片描述

可以看到如果有同名属性的话,后面的属性值会覆盖前面的属性值。

3、有多个源对象

前面的示例都是只有一个源对象,那么如果有多个源对象情况会不会不同呢?我们继续看下面的例子:

    var target={name:'guxin',age:18}
    var source1={state:'signle',age:22}
    var source2={mood:'happy',age:25}
    var result=Object.assign(target,source1,source2)
    console.log(target)

我们来看下运行结果:
在这里插入图片描述
可以看到有多个源对象情况也是和一个源对象一样的。没有同名的属性会直接复制到目标对象上,同名的属性后面的属性值会覆盖前面的同名属性值。

四、注意事项:

1、Object.assign 方法只会拷贝源对象自身的并且可枚举的属性到目标对象,继承属性和不可枚举属性是不能拷贝的。

2、针对深拷贝,需要使用其他办法,因为 Object.assign()他只能进行浅拷贝,拷贝的是属性值。假如源对象的属性值是一个对象的引用,当源对象的属性的复杂数据的值改变之后,目标对象也会改变。

3、目标对象自身也会改变

4、异常会打断后续拷贝任务

五、兼容性

目前IE浏览器不兼容Object.assign(),如果需要兼容IE的话最好不要直接使用这个方法。
————————————————
版权声明:本文为CSDN博主「guxin_duyin」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/guxin_duyin/article/details/88916106

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值