Pré-armazenamento em cache no app Create React com o Workbox

Armazenar recursos em cache com um service worker pode acelerar visitas repetidas e fornecer suporte off-line. O Workbox facilita isso e é incluído no Create React App por padrão.

O Workbox é integrado ao Create React App (CRA) com uma configuração padrão que pré-armazena em cache todos os recursos estáticos no aplicativo com cada build.

Solicitações/respostas com service worker

Por que isso é útil?

Os service workers permitem que você armazene recursos importantes no cache (pré-cache) para que, quando um usuário carregar a página da Web pela segunda vez, o navegador possa extrair esses recursos do service worker em vez de fazer solicitações para a rede. Isso resulta em carregamentos de página mais rápidos em visitas repetidas, além da capacidade de mostrar conteúdo quando o usuário está off-line.

Workbox no CRA

O Workbox é um conjunto de ferramentas que permite criar e manter trabalhadores de serviço. No CRA, o workbox-webpack-plugin já está incluído no build de produção e só precisa ser ativado no arquivo src/index.js para registrar um novo worker de serviço em cada build:

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();

Confira um exemplo de app React criado com o CRA que tem um service worker ativado por este arquivo:

Para saber quais recursos estão sendo armazenados em cache:

  • Para visualizar o site, pressione View App. Em seguida, pressione Fullscreen tela cheia.
  • Pressione "Control+Shift+J" (ou "Command+Option+J" no Mac) para abrir as Ferramentas do desenvolvedor.
  • Clique na guia Rede.
  • Atualize o app.

Em vez de mostrar o tamanho do payload, a coluna Size mostra uma mensagem (from ServiceWorker) para indicar que esses recursos foram recuperados do service worker.

Solicitações de rede com um service worker

Como o service worker armazena em cache todos os recursos estáticos, tente usar o aplicativo off-line:

  1. Na guia Rede do DevTools, ative a caixa de seleção Off-line para simular uma experiência off-line.
  2. Atualize o app.

O aplicativo funciona da mesma forma, mesmo sem uma conexão de rede.

Como modificar estratégias de armazenamento em cache

A estratégia de pré-armazenamento em cache padrão usada pelo Workbox no CRA é cache-first, em que todos os recursos estáticos são buscados do cache do service worker. Se isso falhar (se o recurso não estiver armazenado em cache, por exemplo), a solicitação de rede será feita. É assim que o conteúdo ainda pode ser exibido aos usuários mesmo quando eles estão em um estado off-line completo.

Embora o Workbox ofereça suporte para definir diferentes estratégias e abordagens para armazenar em cache recursos estáticos e dinâmicos, a configuração padrão no CRA não pode ser modificada ou substituída, a menos que você ejetar completamente. No entanto, há uma proposta aberta para analisar a adição de suporte a um arquivo workbox.config.js externo. Isso permite que os desenvolvedores modifiquem as configurações padrão criando um único arquivo workbox.config.js.

Como gerenciar uma estratégia que prioriza o cache

Confiar no cache do service worker primeiro e depois usar a rede é uma excelente maneira de criar sites que são carregados mais rapidamente em visitas subsequentes e funcionam off-line até certo ponto. No entanto, há alguns pontos que precisam ser considerados:

  • Como testar os comportamentos de armazenamento em cache por um worker de serviço?
  • Deve haver uma mensagem para os usuários informando que eles estão visualizando conteúdo em cache?

A documentação da CRA explica esses pontos e muito mais em detalhes.

Conclusão

Use um service worker para pré-cachear recursos importantes no seu app e oferecer uma experiência mais rápida aos usuários, além de suporte off-line.

  1. Se você estiver usando o CRA, ative o worker de serviço pré-configurado em src/index.js.
  2. Se você não estiver usando o CRA para criar um aplicativo React, inclua uma das muitas bibliotecas fornecidas pelo Workbox, como workbox-webpack-plugin, no processo de build.
  3. Fique de olho quando o CRA oferecer suporte a um arquivo de substituição workbox.config.js neste problema do GitHub.