gpt4 book ai didi

javascript - 为什么更新一个对象中的属性会更改另一个对象?

转载 作者:行者123 更新时间:2023-11-30 10:33:46 27 4
gpt4 key购买 nike

我正在通过 ajax 将 JSON 数据加载到一个对象中,将该对象复制到新对象(initData 和 newData)。当我更改 newData 的属性时,initData 的属性也会更改。为什么会这样?

var initData = {};
var newData = {};

function load_data(NDB_No){
$.getJSON(('scripts/jsonencode.php?q=' + NDB_No), function(data) {

for (prop in data){
initData[prop] = data[prop];
newData[prop] = data[prop];
}

console.log('init data: ' + initData.properties.Protein); // "init data: 0.259"
console.log('new data: ' + newData.properties.Protein); // "new data: 0.259"

var n = parseFloat(newData.properties.Protein);
newData.properties.Protein = n+1;

console.log('init data: ' + initData.properties.Protein + 'new data: ' + newData.properties.Protein);
// "init data: 1.259 new data: 1.259"
// why are these the same when I only updated newData object?


});


}

最佳答案

看起来 data[prop] 是一个对象(因为您稍后会引用 newData.properties.Protein)。对象总是通过引用传递,变量只是指向它的指针。

由于您首先获得的是 JSON,因此您的对象是支持 JSON 的,因此您可以使用它来“克隆”该对象:

$.getJSON(...,function(data) {
initData = JSON.parse(JSON.stringify(data));
newData = JSON.parse(JSON.stringify(data));
});

这将确保对象是分开的。还有其他方法可以做到这一点,但这个方法通过使用内置方法避免了手动递归(总是更快)

关于javascript - 为什么更新一个对象中的属性会更改另一个对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15214378/

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