</picture>
Strongly-typed deep and recursive object merging with support for all value types.
Install
pnpm add object-deep-mergeyarn add object-deep-mergenpm install object-deep-mergeBasic Usage
import { merge } from "object-deep-merge";Simply merge two objects, with no nested properties
const merged = merge({ foo: false }, { bar: true });
console.log({ merged });{
"merged": {
"foo": false,
"bar": true
}
}Typed Usage
merge Type Signature
The merge function accepts two optional type generics. TData and TResult.
function merge<TData extends MergeableObject = MergeableObject, TResult extends MergeableObject = TData>(
source: TData,
target: TData,
...targets: Array<TData>
): TResult;[!IMPORTANT]
TheMergeandMergeDeeptypes fromtype-festare great additions to this library. It is not unreasonable to use those types for your merge typing needs.
Without explicitly passing in types the function will infer the shape of the object(s) passed in.
- Passing in
TDatawill validate the shape of the objects passed in. - Passing in
TResultwill override the output type. While this should be used sparingly, it provides a convenient approach for correctly typing partial types into complete types.
Simple Example w/o Generics
type Data = {
name: string;
description: string;
};
const base: Data = { name: "object-deep-merge", description: "merge objects" };
const overrides: Partial<Data> = { description: "merge objects, deeply" };
const merged = merge(base, overrides);
// Type is inferred so the signature becomes:
// function merge<Partial<Data>, Partial<Data>>(source: Partial<Data>, target: Partial<Data>, ...targets: Partial<Data>[]): Partial<Data>
// TData = Partial<Data>
// TResult = Data
console.log({ merged });{
"merged": {
"name": "object-deep-merge",
"description": "merge objects, deeply"
}
}Simple Example w/ TData Generic
[!NOTE] Passing in TData will validate the shape of the objects passed in.
type Data = {
name: string;
description: string;
};
const base: Data = { name: "object-deep-merge", description: "merge objects" };
const overrides: Partial<Data> = { description: "merge objects, deeply" };
const merged: Partial<Data> = merge<Partial<Data>>(base, overrides);
// TData = Partial<Data>
// TResult = Data
console.log({ merged });{
"merged": {
"name": "object-deep-merge",
"description": "merge objects, deeply"
}
}Simple Example w/ TData and TResult Generics
[!NOTE] Passing in
TResultwill override the output type. While this should be used sparingly, it provides a convenient approach for correctly typing partial types into complete types.
type Data = {
name: string;
description: string;
};
const base: Data = { name: "object-deep-merge", description: "merge objects" };
const overrides: Partial<Data> = { description: "merge objects, deeply" };
const merged: Data = merge<Partial<Data>, Data>(base, overrides);
// TData = Partial<Data>
// TResult = Data
console.log({ merged });{
"merged": {
"name": "object-deep-merge",
"description": "merge objects, deeply"
}
}