useReportWebVitals
useReportWebVitals
フックを使用すると、Core Web Vitalsをレポートでき、分析サービスと組み合わせて使用できます。
useReportWebVitals
フックの引数として渡されるmetric
オブジェクトは、以下のプロパティで構成されています:
id
:現在のページ読み込みのコンテキストでのメトリックの一意の識別子name
:パフォーマンスメトリックの名前。可能な値には、Webアプリケーション固有のWeb Vitalsメトリック(TTFB、FCP、LCP、FID、CLS)の名前が含まれます。delta
:メトリックの現在の値と前回の値の差。通常はミリ秒単位で、メトリックの値の経時的な変化を表します。entries
:メトリックに関連するパフォーマンスエントリの配列。これらのエントリは、メトリックに関連するパフォーマンスイベントの詳細な情報を提供します。navigationType
:メトリック収集をトリガーしたナビゲーションの種類を示します。可能な値は"navigate"
、"reload"
、"back_forward"
、"prerender"
です。rating
:メトリック値の定性的な評価で、パフォーマンスの評価を提供します。可能な値は"good"
、"needs-improvement"
、"poor"
です。評価は通常、許容可能またはサブ最適なパフォーマンスを示す所定のしきい値と比較して決定されます。value
:パフォーマンスエントリの実際の値または期間。通常はミリ秒単位で、追跡されているパフォーマンス側面の定量的な測定を提供します。値の出典は、測定される特定のメトリックによって異なり、さまざまなパフォーマンスAPIから取得できます。
Web Vitals
Web Vitalsは、Webページのユーザーエクスペリエンスをキャプチャするのに役立つ一連の有用なメトリックです。以下のWeb Vitalsがすべて含まれています:
- 最初のバイトまでの時間(TTFB)
- 最初のコンテンツフル描画(FCP)
- 最大コンテンツフル描画(LCP)
- 最初の入力遅延(FID)
- 累積レイアウトシフト(CLS)
- 次の描画までの相互作用(INP)
name
プロパティを使用して、これらのメトリックのすべての結果を処理できます。
カスタムメトリック
上記のコアメトリックに加えて、ページのハイドレーションとレンダリングにかかる時間を測定する追加のカスタムメトリックがあります:
Next.js-hydration
:ページがハイドレーションを開始および完了するまでの所要時間(ミリ秒)Next.js-route-change-to-render
:ルート変更後にページのレンダリングを開始するまでの所要時間(ミリ秒)Next.js-render
:ルート変更後にページのレンダリングを完了するまでの所要時間(ミリ秒)
これらのメトリックの結果は個別に処理できます:
これらのメトリックは、User Timing APIをサポートするすべてのブラウザで動作します。
Vercelでの使用
Vercel Speed InsightsはuseReportWebVitals
ではなく、@vercel/speed-insights
パッケージを使用します。useReportWebVitals
フックは、ローカル開発時、または別のサービスでWeb Vitalsを収集する場合に便利です。
外部システムへの結果の送信
サイト上の実際のユーザーパフォーマンスを測定およびトラッキングするために、任意のエンドポイントに結果を送信できます。例:
補足: Google Analyticsを使用する場合、
id
値を使用すると、手動でメトリック分布(パーセンタイルなど)を構築できます。
Google Analyticsへの結果の送信について詳しく読む。