Работа с работниками сервиса

В этой лаборатории кода показано, как зарегистрировать сервис-воркера в вашем веб-приложении и использовать Chrome DevTools для наблюдения за его поведением. Здесь также рассматриваются некоторые методы отладки, которые могут оказаться полезными при работе с сервис-воркерами.

Ознакомьтесь с примером проекта

Файлы в примере проекта, наиболее подходящие для этой лаборатории кода:

  • В начале register-sw.js будет пустым, но он будет содержать код, используемый для регистрации сервисного работника. Он уже загружается через тег <script> внутри index.html проекта.
  • service-worker.js также пуст. Это файл, который будет содержать сервис-воркера для этого проекта.

Добавьте регистрационный код сервисного работника.

Сервис-воркер (даже пустой, например текущий файл service-worker.js ) не будет использоваться, пока он не будет предварительно зарегистрирован . Вы можете сделать это, позвонив по адресу:

navigator.serviceWorker.register(
  '/service-worker.js'
)

внутри вашего файла register-sw.js .

Однако прежде чем добавлять этот код, необходимо принять во внимание несколько моментов.

Во-первых, не каждый браузер поддерживает сервис-воркеров. Это особенно актуально для старых версий браузеров, которые не обновляются автоматически. Поэтому рекомендуется вызывать navigator.serviceWorker.register() условно, после проверки того, поддерживается ли navigator.serviceWorker .

Во-вторых, когда вы регистрируете сервис-воркера, браузер запускает код из вашего файла service-worker.js и потенциально может начать загрузку URL-адресов для заполнения кешей, в зависимости от кода в обработчиках install и activate вашего сервис-воркера.

Запуск дополнительного кода и загрузка ресурсов могут использовать ценные ресурсы, которые в противном случае ваш браузер мог бы использовать для отображения текущей веб-страницы. Чтобы избежать этого вмешательства, рекомендуется отложить регистрацию сервисного работника до тех пор, пока браузер не завершит отрисовку текущей страницы. Удобный способ добиться этого — подождать, пока не будет запущено событие window.load .

Объединив эти два пункта, добавьте этот регистрационный код сервисного работника общего назначения в файл register-sw.js :

if ('serviceWorker' in navigator) {
  window.addEventListener('load', () => {
    navigator.serviceWorker.register('/service-worker.js');
  });
}

Добавьте код регистрации сервисного работника

В файле service-worker.js обычно находится вся логика реализации вашего сервис-воркера. Вы можете использовать сочетание событий жизненного цикла сервис-воркера, Cache Storage API и знаний о сетевом трафике вашего веб-приложения, чтобы создать идеально созданного сервис-воркера, готового обрабатывать все запросы вашего веб-приложения.

Но… это все, чему можно научиться позже. На этом этапе основное внимание уделяется наблюдению за различными событиями сервис-воркера и освоению инструментов разработчика Chrome для отладки состояния вашего сервис-воркера.

Для этого добавьте следующий код в service-worker.js , который будет регистрировать сообщения в консоли DevTools в ответ на различные события (но не делать ничего другого):

self.addEventListener('install', (event) => {
  console.log('Inside the install handler:', event);
});

self.addEventListener('activate', (event) => {
  console.log('Inside the activate handler:', event);
});

self.addEventListener(fetch, (event) => {
  console.log('Inside the fetch handler:', event);
});

Ознакомьтесь с панелью Service Workers в DevTools.

Теперь, когда вы добавили код в файлы register-sw.js и service-worker.js , пришло время посетить Live-версию вашего примера проекта и понаблюдать за сервис-воркером в действии.

  • Чтобы просмотреть сайт, нажмите «Просмотреть приложение» . Затем нажмите Полноэкранный режим полноэкранный .
  • Нажмите «Control+Shift+J» (или «Command+Option+J» на Mac), чтобы открыть DevTools.
  • Откройте вкладку Консоль .

Вы должны увидеть что-то вроде следующих сообщений журнала, показывающих, что сервисный работник установлен и активирован:

Показывает, что сервисный работник установлен и активирован.

Затем перейдите на вкладку «Приложения» и выберите панель «Service Workers» . Вы должны увидеть что-то вроде следующего:

Показывает сведения о сервисном работнике на панели сервисного работника.

Это позволит вам узнать, что существует сервисный работник с исходным URL-адресом service-worker.js для веб-приложения solar-donkey.glitch.me , которое в данный момент активировано и работает. Он также сообщает вам, что в настоящее время существует один клиент (открытая вкладка), которым управляет сервисный работник.

Вы можете использовать ссылки на этой панели, например Unregister или stop , чтобы внести изменения в зарегистрированного в данный момент сервис-воркера в целях отладки.

Запуск потока обновления Service Worker

Одной из ключевых концепций, которые следует понимать при разработке с использованием сервис-воркеров, является идея потока обновлений .

После того как ваши пользователи посетят веб-приложение, которое регистрирует сервис-воркера, они получат код текущей копии service-worker.js установленной в их локальном браузере. Но что произойдет, если вы обновите версию service-worker.js, хранящуюся на вашем веб-сервере?

Когда повторный посетитель возвращается на URL-адрес, находящийся в области действия Service Worker, браузер автоматически запрашивает последнюю версию service-worker.js и проверяет наличие каких-либо изменений. Если что-то в сценарии сервисного работника отличается, новый сервисный работник получит возможность установить, активировать и, в конечном итоге, взять на себя управление.

Вы можете смоделировать этот процесс обновления, вернувшись в редактор кода вашего проекта и внеся любые изменения в код. Одним из быстрых изменений была бы замена

self.addEventListener('install', (event) => {
  console.log('Inside the install handler:', event);
});

с

self.addEventListener('install', (event) => {
  console.log('Inside the UPDATED install handler:', event);
});

После внесения этого изменения вернитесь к Live-версии примера приложения и перезагрузите страницу, оставив вкладку DevTools Application открытой. Вы должны увидеть что-то вроде следующего:

Показывает две установленные версии Service Worker.

Это показывает, что на данный момент установлены две версии вашего сервисного работника. Предыдущая версия, которая уже была активирована, работает и контролирует текущую страницу. Обновленная версия сервис-воркера указана прямо ниже. Он находится в состоянии waiting и будет ожидать, пока все открытые вкладки, контролируемые старым сервис-воркером, не закроются.

Такое поведение по умолчанию гарантирует, что если ваш новый сервис-воркер имеет фундаментальное отличие в поведении от вашего старого (например, обработчик fetch , который отвечает ресурсами, несовместимыми со старыми версиями вашего веб-приложения), он не вступит в силу до тех пор, пока пользователь не вступит в силу. закрыл все предыдущие экземпляры вашего веб-приложения.

Подведение итогов

Теперь вы должны освоиться с процессом регистрации сервисного работника и наблюдением за его поведением с помощью Chrome DevTools.

Теперь вы можете приступить к реализации стратегий кэширования и всех полезных вещей, которые помогут вашему веб-приложению загружаться надежно и быстро.