[TypeScript]Omitについて、実際に実装して理解する。
指定した型から任意のプロパティ除外して新たな型にするOmit
というものがある。
今回はこれを自力で実装しながら理解することを目的とする。
Omitとは
Omit
とは以下の書式を持つ組み込み型で、指定した型のうち、指定したプロパティを除外して新しい型にしてくれるものです。
今回はこれを実装して理解していきます。
すなわち以下のMyOmit
を実装していきます。
MyOmitの実装方針
MyOmit
を実装するにあたって、以下の方針で段階を踏んで実装していきます。
MyOmit<T, K extends string | number | symbol>
に指定されたプロパティのキー以外を羅列する- それぞれのキーに対して、Tの型を設定する
では順に見ていきましょう
MyRequiredに指定されたプロパティのキー以外を羅列する
プロパティのキーを羅列するにはkeyof
を使用します。
そして、keyofの中から指定したキーを除外するのはExcludeを用います。
Exclude
の使用方法については以下を参照
https://tech.teshiblog.com/typescript/typescript-exclude
これで上記の例だとUser
のキーのうち、profile
だけ残すことが出来ました。
後はこの残ったキーに対して、型を設定していくだけですね。
それぞれのプロパティのキーに対して、Tの型を設定する。
TypeScriptにはMapped Types
と呼ばれる、元の型に基づいて新しい型を作成可能な仕組みがあります。
これを用いて、Tの型を設定していきます。
まとめ
今回はOmit
の実装を順を追って実装していきました。
理解出来ましたでしょうか?
Excludeを使うので少し複雑でしたね。
順を追うとtypescriptに不慣れな人でも実装できると思います。
このように簡単な作業に分解することでこのようなものでなく、色々な問題も解決できるのでぜひ