扩展歧视工会

rob*_*kuz 3 typescript mapped-types

是否可以使用 mappend/conditional 类型来转换这个 DU

type MyDU =
| {kind: 'foo'}
| {kind: 'bar'}

type Transformed = DUTransformer<MyDU>
Run Code Online (Sandbox Code Playgroud)

这样我们就得到了以下结果

type Transformed =
| {kind: 'foo', foo: boolean}
| {kind: 'bar', bar: boolean}
Run Code Online (Sandbox Code Playgroud)

Sea*_*ira 5

是的,因为 TypeScript 会通过 union 分配映射类型

type MyDU =
| {kind: 'foo'}
| {kind: 'bar'}

type Kinded<T extends string> = { kind: T }

type DUTransformer<T> = T extends Kinded<infer K> ? T & {[K1 in K]: boolean} : never

type Transformed = DUTransformer<MyDU>
Run Code Online (Sandbox Code Playgroud)

的类型Transformed是:

type Transformed = ({
    kind: 'foo';
} & {
    foo: boolean;
}) | ({
    kind: 'bar';
} & {
    bar: boolean;
})
Run Code Online (Sandbox Code Playgroud)