深度合并对象
深度合并两个对象,使用一个函数来处理两个对象中都存在的键。
- 使用
Object.keys()
获取两个对象的键,创建一个Set
并使用扩展运算符(...
)创建一个包含所有唯一键的数组。 - 使用
Array.prototype.reduce()
将每个唯一键添加到对象中,使用fn
来合并给定对象的值。
const deepMerge = (a, b, fn) =>
[...new Set([...Object.keys(a), ...Object.keys(b)])].reduce(
(acc, key) => ({ ...acc, [key]: fn(key, a[key], b[key]) }),
{}
);
deepMerge(
{ a: true, b: { c: [1, 2, 3] } },
{ a: false, b: { d: [1, 2, 3] } },
(key, a, b) => (key === 'a' ? a && b : Object.assign({}, a, b))
);
// { a: false, b: { c: [ 1, 2, 3 ], d: [ 1, 2, 3 ] } }