【问题标题】:Object.assign vs assignment (=)Object.assign 与赋值 (=)
【发布时间】:2021-10-01 14:56:35
【问题描述】:

我正在尝试创建一个对象的实例。面对Object.assign(),我有点困惑。下面两个代码有什么区别?

const obj3 = Object.assign(obj2, obj1);

和:

let obj2: model;
obj2= obj1;

【问题讨论】:

    标签: javascript object javascript-objects


    【解决方案1】:

    Assignment 只会在内存中创建对完全相同对象的另一个引用。如果您分配,然后通过引用其中一个变量名称进行更改,另一个变量名称也将发生更改,因为它们是相同的。

    Object.assign 会将第二个(以及更多)参数的所有可枚举自己的属性分配给第一个参数,并将返回第一个参数。所以

    const obj3 = Object.assign(obj2, obj1);
    

    有点像

    for (const prop in obj1) {
      obj2[prop] = obj1[prop]
    }
    obj3 = obj2;
    

    (使用普通对象 - 跳过自己的方面)

    它们完全不同。

    【讨论】:

    • 所以 Object.assign 创建了一个新对象并且不引用旧对象,如果我尝试更改 Object.assign 创建的对象,则主对象不会更改。我说的对吗?
    猜你喜欢
    • 2021-09-09
    • 1970-01-01
    • 2019-08-22
    • 1970-01-01
    • 2016-07-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-01-04
    相关资源
    最近更新 更多