メインコンテンツまでスキップ

ユニオン分配 (union distribution)

ユニオン分配はジェネリクスで使われる型変数Tに対しユニオン型が指定された場合、その各要素に対してジェネリクスの型変数を適用することを指します。

たとえば、次のような型エイリアスがあります。

ts
type IsString<T> = T extends string ? true : false;
ts
type IsString<T> = T extends string ? true : false;

この型を使ってstringnumberのユニオン型を持つ変数Tに対してIsStringを適用すると、次のようになります。

ts
type A = IsString<string>;
type A = true
type B = IsString<number>;
type B = false
type C = IsString<string | number>;
type C = boolean
ts
type A = IsString<string>;
type A = true
type B = IsString<number>;
type B = false
type C = IsString<string | number>;
type C = boolean

IsString<T>string型を代入した型エイリアスAtrueとなります。一方string型以外の型を代入した型エイリアスBfalseとなります。

そしてstring | number型を代入した型エイリアスCstring | number型としていっぺんに評価するのではなく、string型とnumber型が個別に評価されます。つまりCIsString<string> | IsString<number>を評価していることと同じになり、結果としてtrue | falseが得られboolean型となります。

もしstring | number型がユニオン分配されずIsStringに適用されたとするとstring | number型はstring型の部分型ではないため、代入することができません。