我正在通过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?
});
}
答案 0 :(得分:4)
看起来data[prop]
是一个对象(因为你后来指的是newData.properties.Protein
)。对象总是通过引用传递,变量只是指向它的指针。
由于您首先获得JSON,因此您的对象具有JSON功能,因此您可以使用它来“克隆”该对象:
$.getJSON(...,function(data) {
initData = JSON.parse(JSON.stringify(data));
newData = JSON.parse(JSON.stringify(data));
});
这将确保对象是分开的。还有其他方法可以做到这一点,但这个方法通过使用内置方法避免手动递归(总是更快)
答案 1 :(得分:0)
这将两者都设置为引用相同的内存空间:
initData[prop] = data[prop];
newData[prop] = data[prop];
...所以当您更改newData
时,您也会更改initData
。您需要创建副本,而不是通过引用分配。我必须跑步,所以我现在无法提供一个例子。