フレームワークコンポーネント
お好みのUIコンポーネントフレームワークを活かしてAstroでウェブサイトを作成してみましょう。
AstroはReact、Preact、Svelte、Vue、SolidJS、AlpineJS、Litのようなさまざまな人気のフレームワークをサポートしています。
インテグレーションをインストール
セクションタイトル: インテグレーションをインストールAstroはReact、Preact、Svelte、Vue、SolidJS、AlpineJS、Litのインテグレーションをオプションとして提供しています。1つまたは複数のAstroインテグレーションをプロジェクトにインストールし、設定できます。
⚙️ Astroのインテグレーションをインストールし、設定するにあたっての詳細はインテグレーションガイドをご覧ください。
⚙️ お好きなフレームワークの例を確認したいですか?astro.newにアクセスして、そのフレームワークのテンプレートを選択してみてください。
フレームワークコンポーネントを利用
セクションタイトル: フレームワークコンポーネントを利用Astroコンポーネントと同じように、JavaScriptフレームワークコンポーネントをAstroページやレイアウト、コンポーネントで使ってみましょう!すべてのコンポーネントは、/src/components
にまとめることも、好きなように整理することもできます。
フレームワークコンポーネントを使用するには、Astroコンポーネントスクリプトで相対パスを指定してインポートします。そして、コンポーネントテンプレートで、他のコンポーネント、HTML要素、JSXライクな式と一緒に使用します。
デフォルトでは、フレームワークのコンポーネントは静的なHTMLとしてレンダリングされます。これはインタラクティブでないコンポーネントをテンプレート化するのに便利で、必要のないJavaScriptをクライアントに送信するのを防ぎます。
インタラクティブなコンポーネント
セクションタイトル: インタラクティブなコンポーネントフレームワークのコンポーネントはclient:*
ディレクティブを使用してインタラクティブ(ハイドレーションした状態)にできます。これはコンポーネントのJavaScriptがいつブラウザに送信されるべきかを定義するためのコンポーネントの属性です。
client:only
を除く全てのclientディレクティブで、コンポーネントはまず最初にサーバー上でレンダリングされて静的なHTMLを生成します。JavaScriptのコンポーネントは指定したディレクティブに従ってブラウザに送信されます。その後コンポーネントはハイドレートしインタラクティブになります。
コンポーネントをレンダリングするために必要なJavaScriptフレームワーク(React、Svelteなど)は、コンポーネント自身のJavaScriptと一緒にブラウザに送信されます。ページ上の複数のコンポーネントが同じフレームワークを使用する場合、フレームワークは一度だけ送信されます。
これらのコンポーネントをAstroで使用した場合、多くのフレームワーク固有のアクセシビリティパターンは同じように動作するはずです。アクセシビリティに関するJavaScriptが適切に読み込まれ、実行されるよう必ずクライアントディレクティブを設定してください。
利用可能なハイドレーションのディレクティブ
セクションタイトル: 利用可能なハイドレーションのディレクティブUIフレームワークコンポーネントで利用可能なハイドレーションのディレクティブがいくつかあります。client:load
、client:idle
、client:visible
、client:media={QUERY}
、client:only={FRAMEWORK}
です。
📚 これらのハイドレーションのディレクティブやその使い方を詳しく知りたい場合はディレクティブのリファレンスのページをご覧ください。
フレームワークを混在させる
セクションタイトル: フレームワークを混在させる同じAstroコンポーネントの中で複数のフレームワークで作られたコンポーネントをインポートし、レンダリングできます。
Astroコンポーネント(.astro
)だけが複数のフレームワークのコンポーネントを含められます。
フレームワークコンポーネントにPropsを渡す
セクションタイトル: フレームワークコンポーネントにPropsを渡すAstroコンポーネントからフレームワークコンポーネントにpropを渡せます。
フレームワークコンポーネントに関数をプロパティとして渡せますが、それはサーバーレンダリングの間だけ機能します。もしこの関数をハイドレードされたコンポーネント(例えば、イベントハンドラーとして)で使用しようとするとエラーが発生します。
これはAstroでは関数をシリアライズ(サーバーからクライアントへの転送)できないためです。
フレームワークコンポーネントに子要素を渡す
セクションタイトル: フレームワークコンポーネントに子要素を渡すAstroコンポーネントでは、フレームワークコンポーネントに子要素を渡せます。各フレームワークは、これらの子要素を参照するための固有のパターンがあります。React、Preact、Solidはchildren
という特別なプロパティを使用し、SvelteとVueは<slot />
という要素を使用します。
さらに、名前付きスロットを使って、特定の子要素をグループ化できます。
React、Preact、Solidでは、これらのスロットはトップレベルのプロパティに変換されます。kebab-case
を使用しているスロット名は、camelCase
に変換されます。
SvelteとVueでは、これらのスロットは<slot>
要素にname
属性を付けて参照できます。また、kebab-case
を使用したスロット名は保持されます。
フレームワークコンポーネントをネストさせる
セクションタイトル: フレームワークコンポーネントをネストさせるAstroファイルの中には、フレームワークコンポーネントの子要素もハイドレーションされたコンポーネントにできます。これは、フレームワークのどれからでも、コンポーネントを再帰的にネストできることを意味します。
フレームワークのコンポーネント自体(例: .jsx
、.svelte
)は複数のフレームワークを混在させることはできません。
これにより、お好みのJavaScriptフレームワークで「アプリ」全体を構築し、親コンポーネントを介してAstroのページにレンダリングできます。
Astroコンポーネントは、ハイドレーションされるフレームワークコンポーネントを含む場合でも、常に静的なHTMLとしてレンダリングされます。つまり、HTMLのレンダリングを行わないpropsしか渡すことができないのです。AstroコンポーネントからフレームワークコンポーネントにReactの「render props」を渡しても、Astroコンポーネントはこのパターンが要求するクライアント実行時の動作を提供できないため、うまくいきません。代わりに、名前付きスロットを使用します。
フレームワークコンポーネントの中でAstroコンポーネントを使用できますか?
セクションタイトル: フレームワークコンポーネントの中でAstroコンポーネントを使用できますか?UIフレームワークコンポーネントは、そのフレームワークの「アイランド(島)」になります。これらのコンポーネントは、そのフレームワークの有効なコードとして、独自のインポートやパッケージのみを使用して完全に記述しなければなりません。UIフレームワークコンポーネント(例:.jsx
や.svelte
)の中で.astro
コンポーネントをインポートすることはできません。
しかし、Astroの<slot />
パターンを利用して、Astroコンポーネントが生成した静的コンテンツを .astro
コンポーネントの中でフレームワークコンポーネントに子要素として渡すことはできます。
Astroコンポーネントをハイドレーションすることはできますか?
セクションタイトル: Astroコンポーネントをハイドレーションすることはできますか?client:
という修飾子を使ってAstroコンポーネントをハイドレーションしようとするとエラーになるはずです。
Astro コンポーネントはクライアントサイドのランタイムを持たないHTMLのみを表示するコンポーネントです。しかし、<script>
タグをAstroコンポーネントのテンプレートの中で使い、グローバルスコープで実行するJavaScriptをブラウザに送信することはできます。
📚 Astroコンポーネントのクライアントサイド<script>
タグについてもっと学ぶ