Мой PWA, недавно созданный с использованием Vue CLI 3, прекрасно работает, за исключением того, что я не могу заставить его кэшировать свои шрифты в течение периода времени, превышающего max-age=0
.
Вот мои настройки:
vue.config.sys
(соответствующая часть)
module.exports = {
pwa: {
workboxOptions: {
exclude: [/\.eot$/, /\.ttf$/],
clientsClaim: true,
skipWaiting: true,
navigateFallback: 'index.html',
runtimeCaching: [
{
urlPattern: /\.(?:woff|woff2)$/,
handler: 'cacheFirst',
options: {
// Use a custom cache name for this route.
cacheName: 'fonts',
// Configure custom cache expiration.
expiration: {
maxEntries: 50,
maxAgeSeconds: 30 * 24 * 60 * 60, // 30 days
// Automatically cleanup if quota is exceeded.
purgeOnQuotaError: true,
},
},
},
],
},
},
};
Результирующий service-worker.js
(используется режим GenerateSW по умолчанию)
data:image/s3,"s3://crabby-images/f7920/f792071ddcb9a3a5fc9b1670a50b1e1744e4528e" alt="service-worker.js"
.htaccess
(папка, из которой подается приложение)
RewriteEngine On
# Redirects http calls to their equivalent https URL
RewriteCond %{HTTPS} !on
RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
# A simple catch-all fallback route used when the URL entered by the user
# doesn't match any of the provided app routes. This code is needed when
# using history mode in vue-router.
FallbackResource index.html
# Prevents directory viewing from a browser window.
Options -Indexes
Chrome Dev Tools Cache Storage Screen Grab
data:image/s3,"s3://crabby-images/fffcf/fffcf51616f1ef9c17f6fe651d6de170388730ff" alt="Screen Grab of Chrome Dev Tools Cache Storage"
Чего мне не хватает?