islands-architecture
ページの大部分が静的で一部のみインタラクティブなサイト向けに、部分的なハイドレーションを実現するIslandsアーキテクチャパターンを解説します。コンテンツ中心のサイトを構築する際に、静的領域と動的領域を効率的に分離したい場合に活用してください。
description の原文を見る
Teaches the islands architecture pattern for partial hydration. Use when building content-heavy sites where most of the page is static and only small regions need interactivity.
SKILL.md 本文
Islands Architecture
目次
使用場面
- 静的コンテンツが主体で、わずかなインタラクティビティが必要なサイト(ブログ、製品ページ、ニュースサイト)に使用してください
- クライアントに送信する JavaScript の量を削減したい場合に役立ちます
- SEO と高速な初回ページロードが優先事項であり、同時に選択的なインタラクティビティが必要な場合に使用してください
手順
- 各ページの静的領域と動的領域を分けて特定する
- Islands Architecture をサポートする Astro、Marko、Eleventy などのフレームワークを使用する
client:visibleなどのディレクティブを使用して、インタラクティブなコンポーネントを独立して hydrate する- ページの大部分を、JavaScript コストがゼロの静的 HTML として保つ
詳細
過剰な JavaScript の読み込みと処理はパフォーマンスに悪影響を及ぼします。しかし、主に静的なウェブサイトであっても、ある程度のインタラクティビティと JavaScript は必要なことが多くあります。私たちは静的レンダリングの様々なバリエーションについて論じてきました。これらは以下のバランスを取ろうとするアプリケーション構築を可能にします:
- クライアント側レンダリング (CSR) アプリケーションに匹敵するインタラクティビティ
- SSR アプリケーションと同等の SEO の利点
SSR の基本原則は、HTML がサーバーで レンダリングされ、クライアント側でそれを rehydrate するために必要な JavaScript とともに配信されることです。Rehydration は、サーバーがレンダリング後、クライアント側で UI コンポーネントの状態を再生成するプロセスです。Rehydration にはコストがかかるため、SSR の各バリエーションは rehydration プロセスの最適化を試みます。これは主に重要なコンポーネントの部分的な hydration またはレンダリング時のコンポーネントストリーミングによって達成されます。ただし、上記の手法で最終的に配信される JavaScript の総量は同じままです。
Islands Architecture という用語は Katie Sylor-Miller と Jason Miller によって普及し、それ以外は静的な HTML の上に独立して配信できる「islands」のインタラクティビティを通じて、配信される JavaScript の量を減らすことを目的としたパラダイムを説明しています。Islands はコンポーネントベースのアーキテクチャであり、静的島と動的島を持つページの区分化されたビューを提案します。ページの静的領域は純粋な非インタラクティブな HTML であり、hydration を必要としません。動的領域は HTML とスクリプトの組み合わせで、レンダリング後に自身を rehydrate することができます。
動的コンポーネントの島
ほとんどのページは静的コンテンツと動的コンテンツの組み合わせです。通常、ページは静的コンテンツと、分離できるインタラクティブな領域が少しで構成されています。例えば:
- ブログ記事、ニュース記事、組織のホームページは、テキストと画像を含み、ソーシャルメディア埋め込みやチャットなどのインタラクティブコンポーネントを備えています。
- e コマース サイトの製品ページは、静的な製品説明とアプリの他のページへのリンクを含みます。画像カルーセルと検索などのインタラクティブコンポーネントはページの異なる領域で利用可能です。
- 典型的な銀行口座詳細ページは、静的なトランザクションのリストと、いくつかのインタラクティビティを提供するフィルタを含みます。
静的コンテンツはステートレス、イベントを発火しない、レンダリング後に rehydration を必要としません。レンダリング後、動的コンテンツ(ボタン、フィルタ、検索バー)はそのイベントに再接続される必要があります。DOM はクライアント側で再生成される必要があります(仮想 DOM)。この再生成、rehydration、イベント処理機能がクライアントに送信される JavaScript に寄与します。
Islands Architecture は、すべての静的コンテンツを含むページのサーバー側レンダリングを促進します。ただし、この場合、レンダリングされた HTML には動的コンテンツのプレースホルダが含まれます。動的コンテンツプレースホルダは自己完結型のコンポーネントウィジェットを含みます。各ウィジェットはアプリのようなもので、サーバーレンダリング出力と、クライアント側でアプリを hydrate するために使用される JavaScript を組み合わせます。
プログレッシブ hydration では、ページの hydration アーキテクチャはトップダウンです。ページは個々のコンポーネントのスケジューリングと hydration を制御します。Islands Architecture では各コンポーネントは独自の hydration スクリプトを持ち、ページ上の他のスクリプトとは独立して非同期で実行されます。1 つのコンポーネントのパフォーマンス問題は他のコンポーネントに影響しません。
Islands の実装
Island Architecture はさまざまなソースから概念を借用し、それらを最適に組み合わせることを目的としています。Jekyll や Hugo などのテンプレートベースの静的サイトジェネレータは、ページへの静的コンポーネントのレンダリングをサポートしています。ほとんどの最新 JavaScript フレームワークは isomorphic rendering もサポートしており、サーバーとクライアントで同じコードを使用して要素をレンダリングできます。
Jason のポストは、コンポーネントを hydrate するためのスケジューリング アプローチを実装するために requestIdleCallback() の使用を提案しています。静的 isomorphic rendering とコンポーネント レベルの部分的な hydration のスケジューリングはフレームワークに組み込むことができ、Islands Architecture をサポートします。したがって、フレームワークは以下をサポートすべきです:
- JavaScript がゼロのサーバーでのページの静的レンダリング。
- 静的コンテンツのプレースホルダを通じた独立した動的コンポーネントの埋め込み。各動的コンポーネントはそのスクリプトを含み、メインスレッドが空き次第 requestIdleCallback() を使用して自身を hydrate できます。
- サーバーでのコンポーネントの isomorphic rendering と、両端で同じコンポーネントを認識するためのクライアントでの hydration を許可します。
フレームワーク
今日、異なるフレームワークが Islands Architecture をサポートすることができます。その中で注目されるものは:
-
Marko: Marko は eBay が開発・保守しているオープンソースフレームワークで、サーバーレンダリングパフォーマンスを改善します。ストリーミングレンダリングと自動的な部分的 hydration を組み合わせることで Islands Architecture をサポートしています。HTML およびその他の静的アセットは、準備ができ次第クライアントにストリーミングされます。自動的な部分的 hydration により、インタラクティブコンポーネントは自身を hydrate できます。Hydration コードはインタラクティブコンポーネントのみに配信され、ブラウザの状態を変更できます。Isomorphic であり、Marko コンパイラは実行される場所(クライアントまたはサーバー)に応じて最適化されたコードを生成します。
-
Astro: Astro は React、Preact、Svelte、Vue などの他のフレームワークで構築された UI コンポーネントから軽量な静的 HTML ページを生成できる静的サイトビルダーです。クライアント側の JavaScript が必要なコンポーネントは、その依存関係とともに個別に読み込まれます。したがって、組み込みの部分的 hydration を提供します。Astro は、表示されるタイミングに応じてコンポーネントを遅延ロードすることもできます。
-
Eleventy + Preact: Markus Oberlehner は、Eleventy(静的サイトジェネレータ)と、部分的に hydrate できる isomorphic Preact コンポーネントの使用を実証しています。遅延 hydration もサポートしています。コンポーネント自体は、そのコンポーネントの hydration を宣言的に制御します。インタラクティブコンポーネントは
WithHydrationラッパーを使用して、クライアント側で hydrate されます。
Marko と Eleventy は Jason が提供した Islands の定義より前に存在しますが、それをサポートするために必要な機能のいくつかを含んでいます。しかし、Astro はこの定義に基づいて構築されており、Islands Architecture を本来的にサポートしています。
サンプル実装
以下は Astro を使用して実装されたサンプルブログページです。ページ SamplePost は 1 つのインタラクティブコンポーネント SocialButtons をインポートしています。このコンポーネントはマークアップを通じて必要な位置で HTML に含まれます。
// Component Imports
import { SocialButtons } from '../../components/SocialButtons.js';
<html lang="en">
<head>
<link rel="stylesheet" href="/blog.css" />
</head>
<body>
<div class="layout">
<article class="content">
<section class="intro">
<h1 class="title">Post title (static)</h1>
<br/>
<p>Post sub-title (static)</p>
</section>
<section class="intro">
<p>This is the post content with images that is rendered by the server.</p>
<p>The next section contains the interactive social buttons component which includes its script.</p>
</section>
<section class="social">
<div>
<SocialButtons client:visible></SocialButtons>
</div>
</section>
</article>
</div>
</body>
</html>
// SocialButtons.js
import { useState } from "preact/hooks";
export function SocialButtons() {
const [count, setCount] = useState(0);
const add = () => setCount((i) => i + 1);
const subtract = () => setCount((i) => i - 1);
return (
<>
<div>{count} people liked this post</div>
<div align="right">
<button onclick={add}>Like</button>
<button onclick={subtract}>Unlike</button>
</div>
</>
);
}
SocialButtons コンポーネントは、その HTML と対応するイベントハンドラを含む Preact コンポーネントです。
コンポーネントは実行時にページに埋め込まれ、クライアント側で hydrate されるため、クリックイベントが必要に応じて機能します。
Astro は HTML、CSS、スクリプト間のクリーンな分離を可能にし、コンポーネントベースの設計を推奨しています。このフレームワークでサイト構築を簡単に開始できます。
長所と短所
Islands Architecture は、サーバー側レンダリング、静的サイト生成、部分的 hydration などのさまざまなレンダリング手法から考え方を組み合わせています。islands を実装することの潜在的な利点のいくつかは以下の通りです。
-
パフォーマンス: クライアントに送信される JavaScript コードの量を削減します。送信されるコードは、インタラクティブコンポーネントに必要なスクリプトのみで構成され、ページ全体の仮想 DOM を再作成し、ページ上のすべての要素を rehydrate するために必要なスクリプトよりはるかに少ないです。JavaScript のサイズが小さいほど、自動的にページロードが高速化され、Time to Interactive (TTI) が改善されます。
-
SEO: すべての静的コンテンツはサーバー側でレンダリングされるため、ページは SEO フレンドリーです。
-
重要なコンテンツの優先順位付け: キーコンテンツ(特にブログ、ニュース記事、製品ページの場合)はほぼすぐにユーザーが利用できます。インタラクティビティのための機能はキーコンテンツの利用後に必要となり、段階的に利用可能になります。
-
アクセシビリティ: 標準的な静的 HTML リンクを使用して他のページにアクセスすることは、ウェブサイトのアクセシビリティの向上に役立ちます。
-
コンポーネントベース: このアーキテクチャは、再利用性と保守性などのコンポーネントベースのアーキテクチャのすべての利点を提供します。
利点にもかかわらず、この概念はまだ初期段階にあります。サポートが限定されているため、いくつかの欠点があります。
- 開発者が Islands を実装するために利用可能な唯一の選択肢は、利用可能ないくつかのフレームワークのいずれかを使用するか、アーキテクチャを自分で開発することです。既存のサイトを Astro または Marko に移行するには、追加の努力が必要になります。
- Jason の初期ポストの他に、このアイデアについては議論がほとんどありません。
- 新しいフレームワークは Islands Architecture をサポートすることを主張しており、どれがあなたに適しているのかをフィルタリングするのが困難です。
- このアーキテクチャはソーシャルメディアアプリなどの非常にインタラクティブなページには適していません。それらはおそらく数千の islands を必要とします。
Islands Architecture の概念は比較的新しいですが、パフォーマンスの利点のために速度を上げる可能性が高いです。これは静的コンテンツをレンダリングするために SSR を使用しながら、ページのパフォーマンスに最小限の影響を持つ動的コンポーネントを通じたインタラクティビティをサポートすることを強調しています。この分野により多くのプレイヤーが登場し、より広い選択肢の実装オプションが利用可能になることを期待しています。
出典
参考資料
ライセンス: MIT(寛容ライセンスのため全文を引用しています) · 原本リポジトリ
詳細情報
- 作者
- patternsdev
- リポジトリ
- patternsdev/skills
- ライセンス
- MIT
- 最終更新
- 不明
Source: https://github.com/patternsdev/skills / ライセンス: MIT
関連スキル
superfluid
Superfluidプロトコルおよびそのエコシステムに関するナレッジベースです。Superfluidについて情報を検索する際は、ウェブ検索の前にこちらを参照してください。対応キーワード:Superfluid、CFA、GDA、Super App、Super Token、stream、flow rate、real-time balance、pool(member/distributor)、IDA、sentinels、liquidation、TOGA、@sfpro/sdk、semantic money、yellowpaper、whitepaper
civ-finish-quotes
実質的なタスクが真に完了した際に、文明風の儀式的な引用句を追加します。ユーザーやエージェントが機能追加、リファクタリング、分析、設計ドキュメント、プロセス改善、レポート、執筆タスクといった実際の成果物を完成させるときに、明示的な依頼がなくても使用します。短い返信や小さな修正、未完成の作業には適用しません。
nookplot
Base(Ethereum L2)上のAIエージェント向け分散型調整ネットワークです。エージェントがオンチェーンアイデンティティを登録する、コンテンツを公開する、他のエージェントにメッセージを送る、マーケットプレイスで専門家を雇う、バウンティを投稿・請求する、レピュテーションを構築する、共有プロジェクトで協業する、リサーチチャレンジを解くことでNOOKをマイニングする、キュレーションされたナレッジを備えたスタンドアロンオンチェーンエージェントをデプロイする、またはアグリーメントとリワードで収益を得る場合に利用できます。エージェントネットワーク、エージェント調整、分散型エージェント、NOOKトークン、マイニングチャレンジ、ナレッジバンドル、エージェントレピュテーション、エージェントマーケットプレイス、ERC-2771メタトランザクション、Prepare-Sign-Relay、AgentFactory、またはNookplotが言及された場合にトリガーされます。
web3-polymarket
Polygon上でのPolymarket予測市場取引統合です。認証機能(L1 EIP-712、L2 HMAC-SHA256、ビルダーヘッダー)、注文発注(GTC/GTD/FOK/FAK、バッチ、ポストオンリー、ハートビート)、市場データ(Gamma API、Data API、オーダーブック、サブグラフ)、WebSocketストリーミング(市場・ユーザー・スポーツチャネル)、CTF操作(分割、統合、償却、ネガティブリスク)、ブリッジ機能(入金、出金、マルチチェーン)、およびガスレスリレイトランザクションに対応しています。AIエージェント、自動マーケットメーカー、予測市場UI、またはPolygraph上のPolymarketと統合するアプリケーション構築時に活用できます。
ethskills
Ethereum、EVM、またはブロックチェーン関連のリクエストに対応します。スマートコントラクト、dApps、ウォレット、DeFiプロトコルの構築、監査、デプロイ、インタラクションに適用されます。Solidityの開発、コントラクトアドレス、トークン規格(ERC-20、ERC-721、ERC-4626など)、Layer 2ネットワーク(Base、Arbitrum、Optimism、zkSync、Polygon)、Uniswap、Aave、Curveなどのプロトコルとの統合をカバーします。ガスコスト、コントラクトのデシマル設定、オラクルセキュリティ、リエントランシー、MEV、ブリッジング、ウォレット管理、オンチェーンデータの取得、本番環境へのデプロイ、プロトコル進化(EIPライフサイクル、フォーク追跡、今後の変更予定)といったトピックを含みます。
xxyy-trade
このスキルは、ユーザーが「トークン購入」「トークン売却」「トークンスワップ」「暗号資産取引」「取引ステータス確認」「トランザクション照会」「トークンスキャン」「フィード」「チェーン監視」「トークン照会」「トークン詳細」「トークン安全性確認」「ウォレット一覧表示」「マイウォレット」「AIスキャン」「自動スキャン」「ツイートスキャン」「オンボーディング」「IP確認」「IPホワイトリスト」「トークン発行」「自動売却」「損切り」「利益確定」「トレーリングストップ」「保有者」「トップホルダー」「KOLホルダー」などをリクエストした場合、またはSolana/ETH/BSC/BaseチェーンでXXYYを経由した取引について言及した場合に使用します。XXYY Open APIを通じてオンチェーン取引とデータ照会を実現します。