PokéRogue
    Preparing search index...

    Type Alias Merge<Destination, Source>

    Merge: Destination extends unknown
        ? Source extends unknown
            ? If<
                IsEqual<Destination, Source>,
                Destination,
                _Merge<Destination, Source>,
            >
            : never
        : never

    Merge two types into a new type. Keys of the second type overrides keys of the first type.

    This is different from the TypeScript & (intersection) operator. With &, conflicting property types are intersected, which often results in never. For example, {a: string} & {a: number} makes a become string & number, which resolves to never. With Merge, the second type's keys cleanly override the first, so Merge<{a: string}, {a: number}> gives {a: number} as expected. Merge also produces a flattened type (via Simplify), making it more readable in IDE tooltips compared to A & B.

    Type Parameters

    • Destination
    • Source
    import type {Merge} from 'type-fest';

    type Foo = {
    a: string;
    b: number;
    };

    type Bar = {
    a: number; // Conflicts with Foo['a']
    c: boolean;
    };

    // With `&`, `a` becomes `string & number` which is `never`. Not what you want.
    type WithIntersection = (Foo & Bar)['a'];
    //=> never

    // With `Merge`, `a` is cleanly overridden to `number`.
    type WithMerge = Merge<Foo, Bar>['a'];
    //=> number
    import type {Merge} from 'type-fest';

    type Foo = {
    [x: string]: unknown;
    [x: number]: unknown;
    foo: string;
    bar: symbol;
    };

    type Bar = {
    [x: number]: number;
    [x: symbol]: unknown;
    bar: Date;
    baz: boolean;
    };

    export type FooBar = Merge<Foo, Bar>;
    //=> {
    // [x: string]: unknown;
    // [x: number]: number;
    // [x: symbol]: unknown;
    // foo: string;
    // bar: Date;
    // baz: boolean;
    // }

    Note: If you want a merge type that more accurately reflects the runtime behavior of object spread or Object.assign, refer to the ObjectMerge type.

    ObjectMerge