如何使用扩展运算符更改对象的嵌套属性?

Tie*_*nto 5 javascript javascript-objects ecmascript-6

这是我的情况的干净版本:

const person1 = {
    name: "Person1 Name",
    hairColor: "Brown",

    backpack: {
        color: "Army-Green",
        content: [
            "item1",
            "item2",
            "..."
        ]
    }
}
Run Code Online (Sandbox Code Playgroud)

我想只改变背包的颜色

我已经在下面尝试过这段代码,但没有成功:

person = {...person1, backpack.color: "New backpack color"}};

person = {...person1, backpack: {...backpack, color: "New backpack color"}};

person = {...person1, backpack: {color: "New backpack color"}};

person = {...person1, backpack = {...backpack, color: "New backpack color"}};
Run Code Online (Sandbox Code Playgroud)

Rau*_*ene 7

const person2 = {...person1, backpack: {...person1.backpack, color: 'Red' }}
Run Code Online (Sandbox Code Playgroud)


Max*_*rou 6

您必须先分散财产,如下所示

const person1 = {
    name: "Person1 Name",
    hairColor: "Brown",

    backpack: {
        color: "Army-Green",
        content: [
            "item1",
            "item2",
            "..."
        ]
    }
}

const person = {...person1, backpack : {...person1.backpack, color : "Red"}}

console.log(person)
Run Code Online (Sandbox Code Playgroud)