Create React App with Workbox でのプレキャッシュ

Service Worker を使用してアセットをキャッシュに保存すると、再訪問時の読み込み速度が向上し、オフライン サポートも提供できます。Workbox を使用すると、この処理を簡単に行えます。Workbox は Create React App にデフォルトで含まれています。

Workbox は Create React App(CRA)に組み込まれており、デフォルト設定では、ビルドごとにアプリケーション内のすべての静的アセットがプリキャッシュされます。

Service Worker を使用したリクエスト / レスポンス

なぜこれが有用なのでしょうか。

サービス ワーカーを使用すると、重要なリソースをキャッシュに保存(プリキャッシュ)できるため、ユーザーがウェブページを 2 回目に読み込むときに、ブラウザはネットワークにリクエストを送信するのではなく、サービス ワーカーからリソースを取得できます。その結果、再訪問時のページの読み込みが速くなるほか、ユーザーがオフラインのときにコンテンツを表示できるようになります。

CRA のワークボックス

ワークボックスは、Service Worker の作成と管理に使用できるツールのコレクションです。CRA では、workbox-webpack-plugin はすでに本番環境ビルドに含まれています。ビルドごとに新しいサービス ワーカーを登録するには、src/index.js ファイルで有効にするだけです。

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import * as serviceWorker from './serviceWorker';
ReactDOM.render(<App />, document.getElementById('root'));

serviceWorker.unregister();
serviceWorker.register();

以下は、このファイルで Service Worker が有効になっている CRA でビルドされた React アプリの例です。

キャッシュに保存されているアセットを確認するには:

  • サイトをプレビューするには、[アプリを表示] を押してから、[全画面表示] 全画面表示 を押します。
  • Ctrl+Shift+J(Mac の場合は Command+Option+J)キーを押して DevTools を開きます。
  • [ネットワーク] タブをクリックします。
  • アプリを再読み込みします。

Size 列には、ペイロード サイズではなく、これらのリソースが Service Worker から取得されたことを示す (from ServiceWorker) メッセージが表示されます。

Service Worker を使用したネットワーク リクエスト

Service Worker はすべての静的アセットをキャッシュに保存するため、オフラインでアプリを使用してみます。

  1. DevTools の [ネットワーク] タブで、[オフライン] チェックボックスをオンにして、オフライン エクスペリエンスをシミュレートします。
  2. アプリを再読み込みします。

ネットワーク接続がなくても、アプリはまったく同じように動作します。

キャッシュ戦略の変更

CRA で Workbox が使用するデフォルトのプリキャッシュ戦略はキャッシュ優先です。この戦略では、すべての静的アセットが Service Worker キャッシュから取得され、取得に失敗した場合(リソースがキャッシュに保存されていない場合など)は、ネットワーク リクエストが実行されます。これにより、ユーザーが完全にオフラインの状態になっていても、コンテンツを配信できます。

Workbox は、静的リソースと動的リソースのキャッシュにさまざまな戦略とアプローチを定義するためのサポートを提供していますが、CRA のデフォルト構成は、完全に取り外さない限り、変更または上書きできません。ただし、外部 workbox.config.js ファイルのサポートの追加については、未解決の提案があります。これにより、デベロッパーは 1 つの workbox.config.js ファイルを作成するだけで、デフォルト設定をオーバーライドできるようになります。

キャッシュ優先戦略の処理

最初に Service Worker キャッシュに依存し、次にネットワークにフォールバックすることは、次回アクセスしたときにサイトがより速く読み込まれ、ある程度オフラインで動作するサイトを構築するための優れた方法です。ただし、考慮すべき点がいくつかあります。

  • Service Worker によるキャッシュ保存動作をテストするにはどうすればよいですか?
  • キャッシュに保存されたコンテンツを表示していることをユーザーに知らせるメッセージが必要ですか?

CRA ドキュメントでは、これらの点などが詳しく説明されています。

まとめ

サービス ワーカーを使用して、アプリ内の重要なリソースをプリキャッシュに保存し、ユーザーに高速なエクスペリエンスとオフライン サポートを提供します。

  1. CRA を使用している場合は、src/index.js で事前構成済みの Service Worker を有効にします。
  2. CRA を使用して React アプリケーションをビルドしていない場合は、Workbox が提供する多くのライブラリ(workbox-webpack-plugin など)のいずれかをビルドプロセスに含めます。
  3. こちらの GitHub の問題で、CRA が workbox.config.js オーバーライド ファイルをサポートするタイミングを確認してください。