jQuery.extend()
有助于以如下方式合并对象:
var a = {
'x': 2,
'y': 3,
'etc': {
'm': 3,
'n': 5
}
};
var b = {
'x': 4,
'z': 1,
'etc': {
'm': 2,
'p': 3
}
};
$.extend(true, a, b); // true for recursively merge
/* Result:
a = {
'x': 4,
'y': 3,
'z': 1,
'etc': {
'm': 2,
'n': 5,
'p': 5
}
};
*/
但我感兴趣的只是已经存在于 中的属性a
,这意味着,例如,如果z
不是 的属性a
,则它不应该出现在结果中。所以预期的结果应该是:
a = {
'x': 4,
'y': 3,
'etc': {
'm': 2,
'n': 5,
}
};
我想知道是否有一种简单的方法可以使用 jQuery 实现这一点,或者只能使用像这样的蛮力来实现(a
在最多 2 层的条件下):
for (var i in b) {
if (a.hasOwnProperty(i)) {
if (typeof a[i] === 'object') {
for (var j in b[i]) {
if (a[i].hasOwnProperty(j)) {
a[i][j] = b[i][j];
}
}
} else {
a[i] = b[i];
}
}
}