React
セットアップ
ブラウザ向けのクイックスタートで、すでにReactアプリケーションの開発のセットアップの仕方を説明しています。要点をまとめると、次の通りです。
ファイル拡張子
.tsx(.tsの代わりに)を使用してください。tsconfig.jsonのcompilerOptionsで"jsx" : "react"を使ってください。JSXとReactの定義をあなたのプロジェクトにインストールします:(
npm i -D @types/react @types/react-dom)。reactを
.tsxファイルにインポートします(import React from "react"となります)。
ReactとTypeScriptのプロジェクトをセットアップする一番簡単な方法は、Create React Appを使うことです。このツールはReactチームから提供されているツールです。公式にTypeScriptのテンプレートが提供されています。Create React Appを使うには、$ npm i -g create-react-appというコマンドでローカルPCにグローバルにインストールできます。そうすれば、Reactの公式Webサイトに書かれているように$ npx create-react-app my-app --template typescriptというコマンドで、最初からTypeScriptを利用可能なプロジェクトを簡単に作成できます。
HTMLタグ vs Component
Reactは、HTMLタグ(文字列)または、React Component(クラス)を表示できます。これらのJavaScriptへのコンパイル結果は同じではありません(例えば、、React.createElement('div')とReact.createElement(MyComponent)のJavaScriptのコンパイル結果に同じではありません)。どちらとして扱われるかは、最初の文字の_ケース_(大文字小文字)です。fooはHTMLタグとして扱われます。そして、Fooはコンポーネントとして扱われます。
型チェック(Type Checking)
HTMLタグ
HTMLタグfooの型はJSX.IntrinsicElements.fooです。これらの主要な型は、セットアップの一部としてインストールした型定義ファイルreact-jsx.d.tsの中で、予め定義されています。下記にその中に含まれる型定義のサンプルを示します。
declare module JSX {
interface IntrinsicElements {
a: React.HTMLAttributes;
abbr: React.HTMLAttributes;
div: React.HTMLAttributes;
span: React.HTMLAttributes;
/// などなど
}
}Functionコンポーネント(Functional Components)
単にReact.FCインターフェースを使ってステートレスなFunctionコンポーネントを定義することができます。React.FCは単に、React.FunctionComponentの短いバージョンです。
クラスコンポーネント(Class Components)
コンポーネントは、propsプロパティに基づいて型チェックされます。コンポーネントは、JSXが、どのように変換されるか、ということを考慮して型チェックされます。例えばJSXのタグの属性は、コンポーネントのpropsの一部である必要があります。
Reactのステートフルなコンポーネントを作成するには、クラスを使用します。型定義ファイルreact.d.tsは、React.Component<Props,State>クラスを定義しています。このクラスを、コンポーネントを作成するときに継承します。このクラスは、そのコンポーネント独自のPropsとStateの型をジェネリクスとして設定できるようになっています。これを以下の例で示します(下記の例では、Stateには空のオブジェクト型を設定しています):
React JSX のヒント: レンダリング可能なインターフェース
ReactはJSXやstringをレンダリングすることができます。これらはすべてReact.ReactNode型に統合されていますので、レンダリング可能なものを受け入れる場合などに使用してください。
React JSX のヒント:コンポーネントのインスタンスを受け入れる
Reactの型定義ファイルは、React.ReactElement<T>という型を提供しています。これを、<T/>クラスコンポーネントのインスタンスを保持できる型アノテーションに利用できます。例えば以下の通りです:
もちろん、これを関数の引数や、コンポーネントのPropsの型として使用することもできます。
React JSXのヒント: propsを受け取り、JSXでレンダリングできるコンポーネントを受け入れる
型React.Component<Props>はReact.ComponentClass<P> | React.StatelessComponent<P>のように2つの種類のコンポーネントの型を統合しています。なので、Props型を受け取り、JSXを使ってレンダリングする_何か_を受け入れることができます。
React JSXのヒント: ジェネリックコンポーネント
これは、期待どおりに動作します。以下に例を示します:
ジェネリック関数
次のようなものがうまくいきます:
しかし、アロー関数のジェネリック関数を利用しようとすると、構文エラーになります。
回避策:ジェネリックのパラメータにextendsを使用すると、コンパイラがジェネリックであることを教えられます。extendsは、ジェネリックの型に制約を付けるためのキーワードです。{}をextendsする、ということは、オブジェクトであれば、何でも良い、ということです。なので、単に構文エラーを回避するために、このようにすることができます:
Reactのヒント: 厳密に型付けされたRef
基本的にRefの変数をユニオン型で定義することによって、nullで初期化できます。そして、それをコンポーネントのrefプロパティに渡したコールバック関数で初期化できます。
これは、DOM要素の参照を保持する変数についても同じです。
型アサーション
既に説明した のように、型アサーションにはas Foo構文を使います。
デフォルトProps
デフォルト値のあるPropsを持ったステートフルなコンポーネント: Nullアサーション演算子
?を使って、デフォルト値のあるPropsを定義できます。このPropsには、(外部からReactの仕組みによって)値が渡されます(これが最も理想的なものとは限りませんが、今思いつく限りでは、シンプルでミニマムなコードです)。
デフォルトPropsのあるFunctionコンポーネント :シンプルなJavaScriptの構文を活用して、TypeScriptの型システムとうまく組み合わせることをお勧めします。下記はその例です:
WebComponentの宣言
もしWebComponentを利用している場合、それはReactの型定義ファイル(@types/react)には定義されていません。しかし、アンビエント宣言(declare)を使って簡単に定義できます。例えば、my-awesome-sliderというWebComponentがあるとします。これは、MyAwesomeSliderPropsを受け取ります。この場合、以下のようになります:
最終更新
役に立ちましたか?