パフォーマンス API

パフォーマンス API は、ウェブアプリケーションのパフォーマンスを測定するために使用される一連の規格です。

概念と使用方法

ウェブアプリケーションを高速に動作させるためには、さまざまなパフォーマンス指標を測定・分析することが重要です。パフォーマンス API は、重要な組み込み指標と、ブラウザーのパフォーマンスタイムラインに自分自身で測定値を追加する機能を提供します。パフォーマンスタイムラインには高精度のタイムスタンプが含まれ、開発者ツールで表示することができます。また、このデータを分析エンドポイントに送信して、パフォーマンス指標を時刻とともに記録することもできます。

それぞれのパフォーマンス指標は単一の PerformanceEntry で表されます。パフォーマンス項目には name, duration, startTime, そして type があります。すべてのパフォーマンス指標は PerformanceEntry インターフェイスを拡張し、さらにそれを修飾しています。

パフォーマンス項目のほとんどは、何もしなくても記録され、Performance.getEntries() または PerformanceObserver からアクセスできます。例えば、 PerformanceEventTiming の項目は、設定された閾値より時間がかかるイベントに対して記録されます。しかし、パフォーマンス API では PerformanceMarkPerformanceMeasure インターフェイスを使用して、自分自身でカスタムイベントを定義したり記録したりすることも可能です。

主となる Performance インターフェイスは Window および Worker グローバルスコーの両方にあり、独自のパフォーマンス項目を追加したり、パフォーマンス項目をクリアしたり、パフォーマンス項目を取得したりすることが可能です。

このインターフェイスでは、さまざまな種類のパフォーマンス項目が記録されるときに、それを待ち受けするために使用することができます。

より概念的な情報については、下記のパフォーマンス API ガイドを参照してください。

パフォーマンス API の UML 図

リファレンス

パフォーマンス API には、以下のインターフェイスが存在します。

EventCounts

performance.eventCounts によって返される、イベント種別毎に発送されたイベント数を保持する読み取り専用のマップです。

LargestContentfulPaint

ビューポート内に表示される最大の画像またはテキストブロックのレンダリング時間を、ページの最初の読み込みを開始した時点から記録して測定します。

LayoutShift

ページ上の要素の動きに基づいて、ウェブページのレイアウトの安定性に関する調査結果を提供します。

LayoutShiftAttribution

シフトした要素に関するデバッグ情報を提供します。

Performance

パフォーマンス測定にアクセスするためのメインインターフェイスです。ウィンドウとワーカーのコンテキストで Window.performance または WorkerGlobalScope.performance を使用することで利用することができます。

PerformanceElementTiming

特定の要素のレンダリングタイムスタンプを測定します。

PerformanceEntry

単一のパフォーマンス指標をカプセル化したパフォーマンスタイムライン上の項目です。すべてのパフォーマンス指標はこのインターフェイスを継承します。

PerformanceEventTiming

イベントの遅延時間、最初の入力遅延 (FID) を測定します。

PerformanceLongAnimationFrameTiming

レンダリングを専有し、他のタスクの実行を妨げる長時間アニメーションフレーム (LoAF) に関する指標を提供します。

PerformanceLongTaskTiming

レンダリングを専有し、他のタスクの実行を妨げる長時間のタスクに関する指標を提供します。

PerformanceMark

パフォーマンスタイムライン上に自分自身で記入するためのカスタムマーカー。

PerformanceMeasure

2 つのパフォーマンス項目間の時刻をカスタム測定します。

PerformanceNavigationTiming

文書を読み込むのにかかる時間など、文書内のナビゲーションイベントを測定します。

PerformanceObserver

パフォーマンスタイムラインに記録される新しいパフォーマンス項目を待ち受けします。

PerformanceObserverEntryList

パフォーマンスオブザーバーで観測された項目のリスト。

PerformancePaintTiming

ウェブページ構築時のレンダリング処理を測定します。

PerformanceResourceTiming

画像、スクリプト、フェッチ呼び出しなどのリソースのリダイレクト開始・終了時刻、フェッチ開始時刻、 DNS ルックアップ開始・終了時刻、レスポンス開始・終了時刻などのネットワーク負荷の指標を測定します。

PerformanceScriptTiming

長時間アニメーションフレーム (LoAF) の発生原因となる個々のスクリプトに関する指標を提供します。

PerformanceServerTiming

HTTP の Server-Timing ヘッダーのレスポンスで送られてくるサーバー指標を示します。

TaskAttributionTiming

タスクの種類と、長時間のタスクを担当するコンテナーを特定します。

VisibilityStateEntry

ページの可視状態が変化した時点を測定します。例えば、タブがフォアグラウンドからバックグラウンド、またはその逆に切り替わった時点です。

ガイド

以下のガイドは、パフォーマンス API の主要な概念を理解し、その能力の概要を提供するのに役立つでしょう。

仕様書

Specification
Element Timing API
Event Timing API
High Resolution Time
Largest Contentful Paint
Layout Instability
Long Tasks API
Navigation Timing Level 2
Paint Timing
Performance Timeline
Resource Timing
Server Timing
User Timing
Long Animation Frames API
Measure Memory API
HTML Standard
# the-visibilitystateentry-interface
HTML Standard
# the-notrestoredreasons-interface

関連情報