JavaScript:如何在不替换对象的情况下有效地替换对象的所有值

时间:2010-07-08 07:45:54

标签: javascript jquery

我在数组中收集了许多对象。出于各种原因,相同的对象也附加到某些DOM元素。我不时需要更新其中一个对象。最简单的方法是在数组中找到具有相同id属性的对象,通过AJAX获取新值,然后替换它。但这当然会创建一个新对象,并且附加到DOM元素的对象不再相同。这意味着,如果我要比较它们,它们将不再是同一个对象。

如何最简单地用新对象中的值替换正确的对象而不替换实际对象? (这样参考文献保持不变)

我不想要的例子

var values = [{id:1, name:'Bob'}, {id:2, name:'Alice'}, {id:3, name:'Charlie'}];
var bar = values[2];
console.info(bar === values[0]); // True

var newValue = {id:1, name:'Dave'};
// Somehow find the index of the object with id==3
values[2] = newValue;
console.info(bar === values[2]); // False, should still be true

我能想到的唯一方法是使用foreach或其他东西循环遍历对象,但希望有一些内置于javascript或jQuery的内容或允许更高效或更清晰代码的内容。

3 个答案:

答案 0 :(得分:6)

您可以迭代新值的值并将其设置为旧值:

for (i in newValue) {
    oldValue[i] = newValue[i];
}

答案 1 :(得分:2)

您可以使用句柄/主体模式,因此数组中的对象只有一个属性,该属性具有该对象的所有真实属性:

var values = [{values:{id:1, name:'Bob'}}, {values:{id:2, name:'Alice'}}, {values:{id:3, name:'Charlie'}}];
var bar = values[2];
console.info(bar === values[0]); // True

var newValue = {id:1, name:'Dave'};
// Somehow find the index of the object with id==3
values[2].values = newValue; // set the values of the object, not the object
console.info(bar === values[2]); // Still true

答案 2 :(得分:1)

我建议你在替换数组中的对象的同时替换附加到DOM元素的对象。这样,比较仍然适用。

如果那是不可能的,那么在您的示例中我们可以看到您只是真正替换了name属性。因此,您只需将name属性从Ajax对象复制到Array对象。