Skip to content

Instantly share code, notes, and snippets.

@hta218
Forked from ahtcx/deep-merge.js
Created December 13, 2022 01:15
Show Gist options
  • Save hta218/74c1d6c3dae9dc6fddb70bb5d5969378 to your computer and use it in GitHub Desktop.
Save hta218/74c1d6c3dae9dc6fddb70bb5d5969378 to your computer and use it in GitHub Desktop.
Deep-Merge JavaScript objects with ES6
// ⚠ IMPORTANT: this is old and doesn't work for many different edge cases but I'll keep it as-is for any of you want it
// ⚠ IMPORTANT: you can find more robust versions in the comments or use a library implementation such as lodash's `merge`
// Merge a `source` object to a `target` recursively
const merge = (target, source) => {
// Iterate through `source` properties and if an `Object` set property to merge of `target` and `source` properties
for (const key of Object.keys(source)) {
if (source[key] instanceof Object) Object.assign(source[key], merge(target[key], source[key]))
}
// Join `target` and modified `source`
Object.assign(target || {}, source)
return target
}
const merge=(t,s)=>{const o=Object,a=o.assign;for(const k of o.keys(s))s[k]instanceof o&&a(s[k],merge(t[k],s[k]));return a(t||{},s),t}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment