要使用服务工作者和缓存API从基本URL离线加载网站,可以按照以下步骤进行操作:
// sw.js
self.addEventListener('install', event => {
event.waitUntil(
caches.open('website-cache').then(cache => {
return cache.addAll([
'/',
'/styles.css',
'/script.js',
'/images/logo.png'
]);
})
);
});
self.addEventListener('fetch', event => {
event.respondWith(
caches.match(event.request).then(response => {
return response || fetch(event.request);
})
);
});
上述代码中,install
事件会在服务工作者首次注册时触发,它会将指定的文件缓存起来。fetch
事件会在每次网络请求发生时触发,它会先查找缓存中是否有对应的响应,如果有则返回缓存的响应,否则发送网络请求并将响应缓存起来。
<script>
if ('serviceWorker' in navigator) {
navigator.serviceWorker.register('/sw.js').then(registration => {
console.log('Service Worker registered with scope:', registration.scope);
}).catch(error => {
console.log('Service Worker registration failed:', error);
});
}
</script>
上述代码会检查浏览器是否支持服务工作者,如果支持则注册服务工作者,并在控制台输出注册的范围(scope)。
install
事件中,将需要离线加载的文件添加到缓存中。上述示例代码中,缓存了基本URL下的根目录、样式表、脚本和图像等资源。根据具体情况,可以自行修改代码以缓存其他资源。fetch
事件中,首先检查缓存中是否有对应的响应。如果有,则返回缓存的响应,否则发送网络请求并将响应缓存起来。使用服务工作者和缓存API可以实现离线加载网站的功能,优势包括:
适用场景包括:
腾讯云相关产品和产品介绍链接地址:
领取专属 10元无门槛券
手把手带您无忧上云