Object.assign

Posted 纸 飞机

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Object.assign相关的知识,希望对你有一定的参考价值。

Object.assign方法用于对象的合并,将源 对象(source)的所有可枚举属性,复制 到目标对象(target) 。

const target = {a: 1};
const source1 = {b: 2};
const source2 = {c: 3};
Object.assign(target, source1, source2);
target//{a:l, b:2, c:3}

Object.assign只拷贝源对象的自身属性 ( 不 拷 贝 继 承 属 性 ) , 也 不 拷 贝 不 可 枚 举 的 属 性 ( enumerable:false) 。 拷贝Symbol值的属性。

Object.assign({b: 'c'},
    Object.defineProperty({},'invisible', {
        enumerable: false,
        value: 'hello'
    })
)
//{b: 'c'}
Object.assign({ a: 'b'),{[Symbol('c')]:'d'})
//{a:'b',Symbol(c):'d'}

Object.assign方法实行的是浅拷贝。如果源对象某个属性的值是对象,那么目标对象拷贝得到的是这个对象的引用。

只能深拷贝一层的对象,所以不是深拷贝。

const objl = {a:{b: 1}};
const obj2 = Object.assign({}, objl);
objl.a.b = 2;
obj2.a.b //2 (是同一个对象)

以上是关于Object.assign的主要内容,如果未能解决你的问题,请参考以下文章

ES6中Object.assign() 方法

使用 Object.assign 和 class/extends 有啥区别?

使用 Firebase 更新文档字段时使用 Object.assign

浅谈ES6的Object.assign()浅拷贝

Javascript |使用Object.assign()合并两个对象数组?

Object.assign()的使用