service worker

12/8/2023 2:49:00 PM
405
0

service worker 是什么

一句话概括

一个服务器与浏览器之间的中间人角色,如果网站中注册了service worker那么它可以拦截当前网站所有的请求,进行判断(需要编写相应的判断程序),如果需要向服务器发起请求的就转给服务器,如果可以直接使用缓存的就直接返回缓存不再转给服务器。从而大大提高浏览体验。

以下是一些细碎的描述

  • 基于web worker(一个独立于JavaScript主线程的独立线程,在里面执行需要消耗大量资源的操作不会堵塞主线程)
  • 在web worker的基础上增加了离线缓存的能力
  • 本质上充当Web应用程序(服务器)与浏览器之间的代理服务器(可以拦截全站的请求,并作出相应的动作->由开发者指定的动作)
  • 创建有效的离线体验(将一些不常更新的内容缓存在浏览器,提高访问体验)
  • 由事件驱动的,具有生命周期
  • 可以访问cache和indexDB
  • 支持推送
  • 并且可以让开发者自己控制管理缓存的内容以及版本

如何使用

  1. 注册Service worker 在你的index.html加入以下内容
/* 判断当前浏览器是否支持serviceWorker */
    if ('serviceWorker' in navigator) {
        /* 当页面加载完成就创建一个serviceWorker */
        window.addEventListener('load', function () {
            /* 创建并指定对应的执行内容 */
            /* scope 参数是可选的,可以用来指定你想让 service worker 控制的内容的子目录。 在这个例子里,我们指定了 '/',表示 根网域下的所有内容。这也是默认值。 */
            navigator.serviceWorker.register('./serviceWorker.js', {scope: './'})
                .then(function (registration) {
 
                    console.log('ServiceWorker registration successful with scope: ', registration.scope);
                })
                .catch(function (err) {
 
                    console.log('ServiceWorker registration failed: ', err);
                });
        });
    }

安装worker:在我们指定的处理程序serviceWorker.js中书写对应的安装及拦截逻辑

/* 监听安装事件,install 事件一般是被用来设置你的浏览器的离线缓存逻辑 */
this.addEventListener('install', function (event) {
 	
    /* 通过这个方法可以防止缓存未完成,就关闭serviceWorker */
    event.waitUntil(
        /* 创建一个名叫V1的缓存版本 */
        caches.open('v1').then(function (cache) {
            /* 指定要缓存的内容,地址为相对于跟域名的访问路径 */
            return cache.addAll([
                './index.html'
            ]);
        })
    );
});

/* 注册fetch事件,拦截全站的请求 */
this.addEventListener('fetch', function(event) {
  event.respondWith(
    // magic goes here
      
      /* 在缓存中匹配对应请求资源直接返回 */
    caches.match(event.request)
  );
});

注意事项

Service worker运行在worker上下文 --> 不能访问DOM

它设计为完全异步,同步API(如XHR和localStorage)不能在service worker中使用

出于安全考量,Service workers只能由HTTPS承载

在Firefox浏览器的用户隐私模式,Service Worker不可用

其生命周期与页面无关(关联页面未关闭时,它也可以退出,没有关联页面时,它也可以启动)

关于VUE

在vue单页应用中,通常加载过一次这个vue应用后。再次在地址栏里输入一个不存在的文件也会被重定向到这个单页应用上。就是使用了此文Service Worker 技术。

如果您在代码中注册了 Service Worker,它可能会拦截对于页面资源的请求并提供缓存的版本,这可能导致您看到 ServiceWorker 相关的信息在浏览器控制台中。您可以通过以下步骤来确认是否使用了 Service Worker:

  1. 检查项目代码中是否有 Service Worker 的注册逻辑,通常是在主 JavaScript 文件中进行注册,例如 main.js 或 registerServiceWorker.js 等文件中。

  2. 在项目的根目录下搜索是否存在类似 service-worker.js 或 sw.js 的文件,这些文件通常是 Service Worker 的实际逻辑代码文件。

  3. 检查您的构建工具配置(如 webpack 配置或 Vue CLI 配置),看是否在构建过程中注册了 Service Worker。

如果您不需要使用 Service Worker,可以简单地将相关代码注释掉或者移除,以避免 Service Worker 对页面资源的拦截和缓存行为。

通常浏览器请求控制台的请求详情显示 ServiceWorker,这可能意味着您的应用程序使用了 Service Worker 技术来提供离线访问、缓存资源或推送通知等功能。值得注意的是,禁用缓存无法阻止Service Worker功能,但是强制刷新是会从服务器重新请求资源。

全部评论



提问