TypeScript の和集合型と交差型
導入
JavaScript の厳密に型指定されたスーパーセットである TypeScript は、JavaScript 開発に堅牢な型チェック機能をもたらします。これらの機能は、開発者がエラーを早期に発見し、より保守しやすいコードを作成するのに役立ちます。 TypeScript の強力な機能には、Union Types と Intersection Types があります。これらの型は、複雑な型を定義する際の柔軟性と精度を提供します。これは、大規模なアプリケーションにとって非常に重要です。
この記事の目的は、TypeScript の共用体型と交差型の概念を説明することです。これらの型を組み合わせて、より表現力豊かな型定義を作成する方法を説明する例に進みます。この記事を読み終えるまでに、TypeScript プロジェクトでこれらの型を効果的に使用する方法をしっかりと理解できるはずです。
それでは、さっそく本題に入りましょう。
ケーススタディ
以下にこのミームがあります。
https://www.picturepunches.com/meme/317642
会話術には暗黙のルールがあります。女性に年齢を聞いてはいけない、男性に給料を聞いてはいけない。しかし、賭け金を増やして、これをさらに興味深いものにしてみましょう。 3 番目のルールを想像してください。プログラマーに未完成のプロジェクトの数を決して尋ねない。秘密の中には、影にしておいた方がよいものもあります。年齢、収入、放棄された副業など、その答えには、聞く準備ができていないような話が含まれていることが多いからです。
OK、最初の 2 つの項目、男性と女性に焦点を当てましょう。
Dont ask 1 | Dont ask 2 | Should ask 1 | Should ask 2 | |
---|---|---|---|---|
Man | Salary | Relationship | Address | Full name |
Woman | Age | Weight | Address | Full name |
TypeScript では、次のような型を作成できます:
type Person = { gender: 'man' | 'woman', dontAsk: 'salary' | 'relationship' | 'age' | 'weight' };
人物タイプに基づいてオブジェクトを作成する場合の問題
const person1: Person = { gender: 'man', dontAsk: 'weight', }; const person2: Person = { gender: 'woman', dontAsk: 'salary', };
上記の 2 つのオブジェクトはどちらも型エラーを表示しません。
この問題を解決するために Intersection タイプと Union タイプが登場しました。
ユニオンの種類
Union Type を使用すると、変数を複数の型のいずれかにすることができます。この例では:
{ gender: 'man', dontAsk: 'salary' | 'relationship' } | { gender: 'woman', dontAsk: 'weight' | 'size' }
タイプ定義のこの部分では、人が次の 2 つの形状のいずれかになる可能性があると述べています。
- 性別が「男性」で、「給与」または「関係」のいずれかを問わないオブジェクト。
- 性別が「女性」であり、「体重」または「年齢」であることを尋ねないでください。
この柔軟性は、複数の形式をとる可能性のあるデータを扱うときに役立ちます。
交差点の種類
交差タイプ は、複数のタイプを 1 つに結合します。交差型の変数は、すべての構成要素型を満たさなければなりません。この例では:
& { address?: string, fullName: string }
タイプ定義のこの部分では、人が以下を持たなければならないと述べています。
- 文字列型のオプションのアドレス プロパティ。
- 文字列型の必須の fullName プロパティ。
結合タイプと交差タイプの組み合わせ
完全な人物タイプは、和集合タイプと交差タイプの両方を組み合わせたものです:
type Person = ({ gender: 'man', dontAsk: 'salary' | 'relationship' } | { gender: 'woman', dontAsk: 'weight' | 'age' }) & { address?: string, fullName: string };
人物オブジェクトは、いずれかの共用体タイプと一致する必要があり、交差タイプで定義されたプロパティも含まれている必要があります。以下に有効な人物オブジェクトをいくつか示します:
const person1: Person = { gender: 'man', dontAsk: 'salary', fullName: 'John Doe' }; const person2: Person = { gender: 'woman', dontAsk: 'weight', fullName: 'Jane Doe', address: '123 Main St' };
person1 を年齢を尋ねずに定義すると、エラーが表示されます。 TypeScript のサポートが組み込まれている Visual Studio Code では、オブジェクトをホバーするとエラーが表示されます。
まとめ
TypeScript では、ユニオン型 により変数を複数の型の 1 つにすることができ、交差型 は複数の型を 1 つに結合します。これらの型を理解して使用することで、より柔軟で堅牢な TypeScript コードを作成できます。人物タイプの例は、これらの概念を組み合わせて複雑で正確なタイプ定義を作成する方法を示しています。
TypeScript を効果的に使用すると、コードの保守性が大幅に向上します。新しい開発者がチームに加わった場合、明確な型定義により、長い説明の必要性が軽減されます。チームはコードを解読する代わりに、プロジェクトのフローと目標について話し合うことに集中でき、生産性とコラボレーションが向上します。
以上がTypeScript の和集合型と交差型の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptコアデータ型は、ブラウザとnode.jsで一貫していますが、余分なタイプとは異なる方法で処理されます。 1)グローバルオブジェクトはブラウザのウィンドウであり、node.jsのグローバルです2)バイナリデータの処理に使用されるNode.jsの一意のバッファオブジェクト。 3)パフォーマンスと時間の処理にも違いがあり、環境に従ってコードを調整する必要があります。

javascriptusestwotypesofcomments:シングルライン(//)およびマルチライン(//)

PythonとJavaScriptの主な違いは、タイプシステムとアプリケーションシナリオです。 1。Pythonは、科学的コンピューティングとデータ分析に適した動的タイプを使用します。 2。JavaScriptは弱いタイプを採用し、フロントエンドとフルスタックの開発で広く使用されています。この2つは、非同期プログラミングとパフォーマンスの最適化に独自の利点があり、選択する際にプロジェクトの要件に従って決定する必要があります。

PythonまたはJavaScriptを選択するかどうかは、プロジェクトの種類によって異なります。1)データサイエンスおよび自動化タスクのPythonを選択します。 2)フロントエンドとフルスタック開発のためにJavaScriptを選択します。 Pythonは、データ処理と自動化における強力なライブラリに好まれていますが、JavaScriptはWebインタラクションとフルスタック開発の利点に不可欠です。

PythonとJavaScriptにはそれぞれ独自の利点があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1. Pythonは、データサイエンスやバックエンド開発に適した簡潔な構文を備えた学習が簡単ですが、実行速度が遅くなっています。 2。JavaScriptはフロントエンド開発のいたるところにあり、強力な非同期プログラミング機能を備えています。 node.jsはフルスタックの開発に適していますが、構文は複雑でエラーが発生しやすい場合があります。

javascriptisnotbuiltoncorc;それは、解釈されていることを解釈しました。

JavaScriptは、フロントエンドおよびバックエンド開発に使用できます。フロントエンドは、DOM操作を介してユーザーエクスペリエンスを強化し、バックエンドはnode.jsを介してサーバータスクを処理することを処理します。 1.フロントエンドの例:Webページテキストのコンテンツを変更します。 2。バックエンドの例:node.jsサーバーを作成します。

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール
