Да, это означает именно это. Идея проста: ответить немедленно из кэша, а затем обновить sh кэш в фоновом режиме для в следующий раз .
Все сценарии ios, где не всегда важно получать самую последнюю версию страницы / приложения =) Я использую устаревшую стратегию для двух разных веб-приложений: одно для транспортных услуг c и одно для отображения информации меню ресторана. Многие сайты / приложения прекрасно с этим справляются, но, конечно, не все.
Одна очень важная вещь, которую следует отметить здесь на # 2: Вы можете, например,. используйте устаревшую проверку только для активов c. Таким образом, ваши html, js, css, изображения и т.д. c. будет кэшироваться и быстро предоставляться пользователю, но данные, извлекаемые динамически из API, могут все еще быть свободными sh. Для некоторых приложений это работает, для некоторых других не очень хорошо. Зависит полностью от приложения. Конечно, вы должны помнить, что не следует изменять семантику вашего API, если пользователь запускает предыдущую версию приложения и т. Д. c.
Невозможно в любом автомате c. Однако вы могли бы создать канал сообщений между Service Worker и «обычным JS кодом на странице» с помощью API window.postMessage. Вы можете прослушать определенные сообщения на странице, а затем от работника сервиса отправить сообщение, если произошло важное изменение и кэш был обновлен. Затем вы можете либо показать пользователю подсказку о том, что страницу действительно нужно перезагрузить прямо сейчас, либо даже принудительно перезагрузить ее с JS. Вы должны будете поместить этот лог c определения того, когда произошло важное обновление в Service Worker, конечно.