gpt4 book ai didi

javascript - 为什么改变一个属性(对象)也会改变另一个单独声明的属性?

转载 作者:行者123 更新时间:2023-12-01 01:03:17 24 4
gpt4 key购买 nike

我有 2 个属性声明如下:

ngOnInit() {
this.defaultRequirements = myData.property1.countryDocument; //should never change
this.filteredRequirements = myData.property1.countryDocument;
}

当我运行此 onFilter 函数时,defaultRequirements 属性也会发生变化。

onFilter(selectedSections) {
let index = -1;

this.defaultRequirements.forEach(country => {
index++;
const filteredSectionsList = [];

country.section.forEach(section => {
selectedSections.value.forEach(selectedSelection => {
const selection = selectedSelection.split(/\s*[-]\s*/);

if (country.countryCode === selection[0]) {
console.log('matched');
filteredSectionsList.push(section);
}
});

const countryObj = Object.assign({}, country, {
section: [...filteredSectionsList]
})

// Here is the issue, when filtering, this.defaultRequirements also gets changed!
this.filteredRequirements[index] = countryObj;


})
})

}

问题

我不明白如何改变 this.filteredRequirements 也改变 this.defaultRequirements (它们都等于同一件事)!如何避免这种行为并使 defaultRequirements 不受对filteredRequirements 所做的更改的影响?

最佳答案

好的,所以您声明的对象 myData.property1.countryDocument 是一个非原始/引用值。因此,这意味着 this.defaultRequirementsthis.filteredRequirements 都指向同一条数据。

如果您使用原始值(例如:字符串)来执行此操作,您将获得一个副本;因此 this.defaultRequirementsthis.filteredRequirements 将完全独立,并且可以进行操作而不会相互影响。

按照您想要的方式复制/复制对象是完全可能的,并且已经有很多关于它的讨论,我不会重复;我建议you take a look at this这很好地覆盖了它。

关于javascript - 为什么改变一个属性(对象)也会改变另一个单独声明的属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55864323/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com