Skip to content

Latest commit

 

History

History
190 lines (133 loc) · 8.12 KB

File metadata and controls

190 lines (133 loc) · 8.12 KB

Fast start with PWA. Service Workers. Кеширование

Что такое Progressive Web Apps

Веб-проекты, которые выглядят и ведут себя, как мобильные приложения:

  • Работают в режиме offline
  • Имеют иконку на рабочем столе
  • Синхронизируют данные в фоновом режиме

PWA


Плюсы и возможности

Плюсы

  • Надежные - моментальная загрузка, вы никогда не увидите динозаврика
  • Быстрые - быстрый отклик на действия пользователя с плавной анимацией и скроллом
  • Чарующие - предоставляется максимально возможный нативный пользовательский опыт

Возможности

  • Push уведомления
  • Фоновая синхронизация
  • Доступность offline
  • Возможность установки на рабочий экран телефона
  • Доступ к камере устройства
  • Доступ к геопозиции ...

PWA и SPA

SPA можно преобразовать в PWA, так же как и любую другую веб-страницу


Основные "слоны" PWA

  • Server Workers
  • Фоновая синхронизация
  • Манифест, разрешающий добавление на рабочий экран
  • Работа по HTTPS
  • Push уведомления

Lighthouse

Расширение диагностики сайта под Chrome. Проверяет:

  • Как быстро грузится сайт
  • Форматы картинок и их сжатие
  • Неиспользуемый css
  • SEO
  • Best practice
  • Соответствие требованиям PWA
    • Скорость загрузки в 3G
    • Доступность offline
    • Возможность установить

manifest.json

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

Наличие этого файла обязательно в Chrome для показа предложения Add to Home Screen


Web App Manifest Generator

Сервис генерации манифеста для проекта (open source)

https://app-manifest.firebaseapp.com/

Web App Manifest Generator


HTML

Добавьте в тэг head

<link rel="manifest" href="/manifest.json">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="theme-color" content="#2196f3">

Тестирование на реальном устройстве

  1. Chrome dev tools -> more tools -> remote devices
  2. Дать доступ на экране устройства
  3. Поставить галочку Port forwarding, добавить новое правило с адресом PWA (## localhost:3000)
  4. Кликнуть по имени устройства
  5. New tab -> адрес PWA -> inspect

Service Workers

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

Service Worker

Browser support

Service Workers Browser support


Service Worker lifecycle

  1. register
  2. installation
  3. activation
  4. idle
  5. termination

Service Worker lifecycle

serviceWorker.js

Service Worker

app.js

Service Worker


Когда обновляется Service Worker?

  • При закрытии вкладки со старым процессом и открытии новой
  • Добавить строчку self.skipWaiting(); в listener для install

Кеширование с Service Workers

Зачем?

  • Плохое соединение
  • Нет соединения (лифт/метро)
  • Lie-Fie

Как?

Cache API - механизм для хранения пары запрос/ответ (без поддержки в Safari)

Что?

  • js
  • css
  • картинки
  • шрифты

Cache

cashes

Объект, отвечающий за взаимодействие с кешем

Основые методы:

  • match(Request) - Проверяет, является ли данный Request ключом в любом из объектов Cache, отслеживаемых объектом CacheStorage, и возвращает Promise, который успешно завершится, когда найдет совпадение.
  • open(cacheName) - Возвращает Promise, который успешно завершится, когда объект Cache найдет необходимый объект с cacheName (если такого нет, то создаст новый).
  • has(cacheName) - Возвращает Promise, который успешно завершится и вернет true, если объект Cache содержит кеш с установленным cacheName.

Динамическое кеширование

Метод put позволяет добавлять данные налету. cache_dyn

Установка на рабочий экран телефона

У window есть метод e.prompt() и listener beforeinstallprompt, который можно вызвать, если приложение соответствует определенным требованиям (в Chrome отрабатывает автоматически).

  • Приложение еще не установлено
  • Пользователь взаимодействовал с доменом минимум 30 секунд
  • Приложение соответствует требованиям PWA

Полезные ссылки