Я не эксперт в этом, но я уверен, что следующие ссылки помогут вам с вашими сомнениями.
https://angular.io/guide/service-worker-getting-started#whats-being-cached
Что кешируется?
Обратите внимание, что все файлы, необходимые браузеру для визуализации этого приложения, кэшируются. Стандартная конфигурация ngsw-config.json настроена для кэширования определенных ресурсов, используемых CLI:
index.html.
favicon.ico.
Создание артефактов (пакеты JS и CSS).
Все, что находится под активами.
Изображения и шрифты прямо под настроенным outputPath (по умолчанию ./dist//) или resourcesOutputPath. См. Ng build для получения дополнительной информации об этих параметрах.
А ссылка ниже содержит информацию о Работник службы и кэширование ресурсов приложения . из которых я хотел бы, чтобы вы прочитали о версиях приложений , проверках обновлений и целостности ресурса .
https://angular.io/guide/service-worker-devops#service-worker-and-caching-of-app-resources
Я также вставляю содержание этих трех разделов здесь, просто чтобы не делать этот ответ "ответом только по ссылке"
Версии приложения
В контексте работника службы Angular «версия» - это набор ресурсов, представляющих конкретную сборку приложения Angular. Каждый раз, когда развертывается новая сборка приложения, работник службы рассматривает эту сборку как новую версию приложения. Это верно, даже если обновляется только один файл. В любой момент времени работник сервиса может иметь несколько версий приложения в своем кэше, и он может обслуживать их одновременно. Для получения дополнительной информации см. Раздел «Вкладки приложения» ниже.
Чтобы сохранить целостность приложения, работник службы Angular группирует все файлы в одну версию. Файлы, сгруппированные в версию, обычно включают файлы HTML, JS и CSS. Группирование этих файлов имеет важное значение для целостности, поскольку файлы HTML, JS и CSS часто ссылаются друг на друга и зависят от конкретного содержимого. Например, файл index.html может содержать тег, ссылающийся на bundle.js, и он может пытаться вызвать функцию startApp () из этого скрипта. Каждый раз, когда обслуживается эта версия index.html, соответствующая bundle.js должна обслуживаться вместе с ней. Например, предположим, что функция startApp () переименована в runApp () в обоих файлах. В этом случае недопустимо использовать старый index.html, который вызывает startApp (), вместе с новым пакетом, который определяет runApp ().
Эта целостность файла особенно важна при отложенной загрузке модулей,Пакет JS может ссылаться на многие ленивые чанки, а имена ленивых чанков уникальны для конкретной сборки приложения. Если работающее приложение в версии X пытается загрузить отложенный фрагмент, но сервер уже обновился до версии X + 1, операция отложенной загрузки завершится неудачей.
Идентификатор версии приложения определяется содержимымвсех ресурсов, и он меняется, если любой из них меняется. На практике версия определяется содержимым файла ngsw.json, который содержит хеши для всего известного содержимого. Если какой-либо из кэшированных файлов изменится, хеш файла изменится в ngsw.json, в результате чего рабочий-сервис Angular будет рассматривать активный набор файлов как новую версию.
С учетом поведения версий сервисного работника Angularсервер приложений может гарантировать, что приложение Angular всегда имеет согласованный набор файлов.
Проверка обновлений
Каждый раз, когда пользователь открывает или обновляет приложение, AngularСервисный работник проверяет наличие обновлений для приложения, просматривая обновления манифеста ngsw.json. Если обновление найдено, оно загружается и кэшируется автоматически и будет обслуживаться при следующей загрузке приложения.
Целостность ресурса
Одним из возможных побочных эффектов длительного кэширования является непреднамеренное кэширование недопустимого ресурса. В обычном HTTP-кэше жесткое обновление или истечение срока действия кэша ограничивают негативные последствия кэширования неверного файла. Работник службы игнорирует такие ограничения и эффективно долго кэширует все приложение. Следовательно, важно, чтобы работник службы получил правильное содержимое.
Для обеспечения целостности ресурса работник службы Angular проверяет хэши всех ресурсов, для которых у него есть хэш. Обычно для приложения, созданного с помощью Angular CLI, это все в каталоге dist, охватываемом конфигурацией src / ngsw-config.json пользователя.
Если конкретный файл не проходит проверку, работник службы Angular пытается перезапустить-выбор содержимого с помощью параметра URL «разорение кэша», чтобы исключить влияние браузера или промежуточного кэширования. Если это содержимое также не проходит проверку, работник службы считает всю версию приложения недействительной и перестает обслуживать приложение. При необходимости работник службы переходит в безопасный режим, в котором запросы возвращаются в сеть, решая не использовать свой кэш, если велика вероятность обслуживания недопустимого, поврежденного или устаревшего содержимого.
Могут возникнуть несоответствия хеша длямножество причин:
- Кэширование слоев между исходным сервером и конечным пользователем может обслуживать устаревший контент.
- Неатомарное развертывание может привести к тому, что работник службы Angular увидит частично обновленный контент.
- Ошибки в процессе сборки могут привести к обновлению ресурсов без обновления ngsw.json. Также может произойти обратное, что приведет к обновлению ngsw.json без обновленных ресурсов.