Вебинары Разобраться в IT Реферальная программа
Программирование Аналитика Дизайн Маркетинг Управление проектами
02 Июн 2023
3 мин
1079

Как создать сайт с использованием технологии Service Workers

Узнайте, как создать быстрый и надежный сайт с использованием технологии Service Workers в нашей доступной статье для новичков!

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

Что такое Service Workers?

Service Workers — это скрипты, которые работают в фоновом режиме и выполняют различные задачи, такие как кэширование содержимого, обработка сетевых запросов, отправка push-уведомлений и синхронизация данных.

👉 Важно: Service Workers доступны только в браузерах, поддерживающих технологию, и работают только на сайтах с HTTPS-соединением.

Регистрация Service Worker

Для начала нам нужно зарегистрировать Service Worker в нашем веб-приложении. Обычно это делается в основном файле JavaScript:

if ('serviceWorker' in navigator) {
  window.addEventListener('load', () => {
    navigator.serviceWorker.register('/service-worker.js')
      .then(registration => {
        console.log('Service Worker зарегистрирован успешно:', registration);
      })
      .catch(error => {
        console.log('Ошибка регистрации Service Worker:', error);
      });
  });
}

Создание файла Service Worker

Теперь создадим файл service-worker.js, который будет содержать логику работы нашего Service Worker. Вначале мы определим несколько важных переменных:

const CACHE_NAME = 'my-cache-v1';
const urlsToCache = [
  '/',
  '/styles/main.css',
  '/scripts/main.js',
  '/images/logo.png',
];

Затем, воспользуемся событием install, чтобы открыть кэш и добавить в него указанные ресурсы:

self.addEventListener('install', event => {
  event.waitUntil(
    caches.open(CACHE_NAME)
      .then(cache => {
        console.log('Открыт кэш:', CACHE_NAME);
        return cache.addAll(urlsToCache);
      })
  );
});

Теперь добавим обработчик события fetch, чтобы наш Service Worker мог перехватывать сетевые запросы и отвечать на них:

self.addEventListener('fetch', event => {
  event.respondWith(
    caches.match(event.request)
      .then(response => {
        if (response) return response;

        return fetch(event.request).then(
          response => {
            if (!response || response.status !== 200 || response.type !== 'basic') {
              return response;
            }

            const responseToCache = response.clone();

            caches.open(CACHE_NAME)
              .then(cache => {
                cache.put(event.request, responseToCache);
              });

            return response;
          }
        );
      })
  );
});

Обновление и удаление старых кэшей

Для обновления и удаления старых кэшей, мы можем использовать событие activate:

self.addEventListener('activate', event => {
  const cacheWhitelist = [CACHE_NAME];

  event.waitUntil(
    caches.keys()
      .then(cacheNames => Promise.all(
        cacheNames.map(cacheName => {
          if (cacheWhitelist.indexOf(cacheName) === -1) {
            return caches.delete(cacheName);
          }
        })
      ))
  );
});

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

Не забудьте продолжать изучать веб-разработку и углублять свои знания о Service Workers! Если вы ищете курс по веб-разработке, рекомендую обратить внимание на знакомую школу 😊

Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей

Добавить комментарий