TypeScript は JavaScript の記述方法に革命をもたらし、開発プロセスに静的型付けと強化されたツールをもたらしました。その最も強力な機能の 1 つはジェネリックです。これにより、さまざまなタイプで動作する再利用可能なコンポーネントを作成できます。この投稿では、TypeScript ジェネリックを深く掘り下げ、コードの柔軟性と型安全性をどのように向上させることができるかを探っていきます。
ジェネリックは、単一のタイプではなくさまざまなタイプで機能するコンポーネントを作成する方法を提供します。これらは、型情報を犠牲にすることなくさまざまなデータ型を処理できるコンポーネントを作成する場合に特に役立ちます。
簡単な例から始めましょう:
function identity<T>(arg: T): T { return arg; } let output = identity<string>("myString"); console.log(output); // Output: myString
この例では、T はユーザーが指定した型を取得する型変数です。これにより、後でその型情報を使用できるようになります。
ジェネリックは、柔軟で再利用可能なコードを作成するために関数でよく使用されます。より実践的な例を次に示します:
function firstElement<T>(arr: T[]): T | undefined { return arr[0]; } let numbers = [1, 2, 3, 4, 5]; let strings = ["a", "b", "c"]; console.log(firstElement(numbers)); // Output: 1 console.log(firstElement(strings)); // Output: "a"
この関数は任意の型の配列で動作し、その型の最初の要素を返すか、配列が空の場合は未定義を返します。
ジェネリックをインターフェイスで使用して、柔軟なデータ構造を作成することもできます。
interface KeyValuePair<K, V> { key: K; value: V; } let pair: KeyValuePair<string, number> = { key: "age", value: 30 };
クラスはジェネリックスを利用して再利用可能なコンポーネントを作成することもできます。
class Queue<T> { private data: T[] = []; push(item: T) { this.data.push(item); } pop(): T | undefined { return this.data.shift(); } } let numberQueue = new Queue<number>(); numberQueue.push(10); numberQueue.push(20); console.log(numberQueue.pop()); // Output: 10
この Queue クラスはあらゆる種類のデータを処理でき、使用全体を通じて型安全性を提供します。
ジェネリックが使用できる型を制限したい場合があります。制約を使用してこれを行うことができます:
interface Lengthwise { length: number; } function logLength<T extends Lengthwise>(arg: T): void { console.log(arg.length); } logLength("Hello"); // Works logLength([1, 2, 3]); // Works logLength(3); // Error: Number doesn't have a length property
この例では、T を長さプロパティを持つ型に制限します。
ジェネリックは、コードの再利用と型の安全性を高める TypeScript の強力な機能です。ジェネリックスをマスターすると、さまざまな型で動作する、より柔軟で堅牢なコードを作成できます。 TypeScript を使用した開発を続けるときは、コードの柔軟性と保守性を向上させるためにジェネリックスを使用する機会を探してください。
ジェネリックを習得する鍵は練習であることを覚えておいてください。既存のコードの一部をリファクタリングしてジェネリックを使用してみると、コードの再利用性と型安全性の点で利点がすぐにわかるでしょう。
その他の Typescript チュートリアル
以上がTypeScript ジェネリックをマスターする: コードの再利用性と型の安全性を強化するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。