>웹 프론트엔드 >JS 튜토리얼 >서비스워커에 대한 자세한 설명을 자바스크립트로!

서비스워커에 대한 자세한 설명을 자바스크립트로!

青灯夜游
青灯夜游앞으로
2020-12-03 17:44:244092검색

이 글에서는 JavaScript API - 서비스 워커를 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

서비스워커에 대한 자세한 설명을 자바스크립트로!

관련 권장 사항: "프로그래밍 소개"

서비스 워커란 무엇입니까

서비스 워커는 웹 애플리케이션에 지속 가능한 고급 백그라운드 처리 기능을 제공하기 위해 Chrome 팀에서 제안하고 권장하는 WEB API입니다. WEB API 표준은 2013년 초안이 작성되었으며 2014년 W3C WEB 표준 초안에 통합되었습니다. 현재 초안 단계에 있습니다.

서비스 워커의 주요 기능은 페이지에 성공적으로 등록되고 설치된 후 브라우저 백그라운드에서 실행되며 페이지 새로 고침의 영향을 받지 않고 범위 내의 모든 페이지에 대한 HTTP 요청을 모니터링하고 차단할 수 있다는 것입니다.

서버와 브라우저 사이의 중개자 역할과 유사합니다. 서비스워커가 웹사이트에 등록되어 있으면 현재 웹사이트의 모든 요청을 가로채서 판단할 수 있습니다(해당하는 내용을 작성해야 함). 판단 프로그램) 서버에 요청해야 하는 경우 서버로 전달됩니다. 캐시를 직접 사용할 수 있는 경우에는 캐시로 직접 반환되며 서버로 전달되지 않습니다. 이는 브라우징 경험을 크게 향상시킵니다. service worker 那么它可以拦截当前网站所有的请求,进行判断(需要编写相应的判断程序),如果需要向服务器发起请求的就转给服务器,如果可以直接使用缓存的就直接返回缓存不再转给服务器。从而大大提高浏览体验。

서비스워커에 대한 자세한 설명을 자바스크립트로!

Service Worker 可以启用以前原生应用程序专有的一组功能。 Service Worker 的初稿已于2014年发布,现在所有主流浏览器都支持它们。

就像已经指出的定义一样,Service Worker 是网络代理。 这意味着它们可以控制页面中的所有网络请求,并且可以对其进行编程,使用缓存的进行响应。

Service Worker 特点

  • 网站必须使用 HTTPS。除了使用本地开发环境调试时(如域名使用 localhost)
  • 运行于浏览器后台,可以控制打开的作用域范围下所有的页面请求
  • 单独的作用域范围,单独的运行环境和执行线程
  • 不能操作页面 DOM。但可以通过事件机制来处理

如何注册 Service Worker

注册 Service Worker 不需要太多代码,只需要一个用于Service Worker 代码的 JS 文件,一般取名为 service-worker.js

// 首先检查浏览器是否支持 Service Worker
if ('serviceWorker' in navigator) {
  navigator.serviceWorker
    .register('/sw/service-worker.js')
    .then(function(registration) {
      console.log(registration);
    })
    .catch(function(err) {
      console.log(err);
    });
}

其实关键代码只有一行:

navigator.serviceWorker.register('/sw/service-worker.js')

注意:

Service Worker 的注册路径决定了其 scope 默认作用范围。示例中 service-worker.js 是在 /sw 路径下,这使得该 Service Worker 默认只会收到 /sw 路径下的 fetch事件。如果存放在网站的根路径下,则将会收到该网站的所有 fetcg事件。

如果希望改变它的作用域,可在第二个参数设置 scope范围。示例中将其改为了根目录,即对整个站点生效。

另外应意识到这一点:Service Worker 没有页面作用域的概念,作用域范围内的所有页面请求都会被当前激活的 Service Worker 所监控。

Service Worker 可以启用哪些功能?

在本节中,我将进一步详细介绍Service Worker的功能,包括一些小代码示例。

服务工作者启用以下功能,这些功能也是 PWA的核心:

  • 离线功能
  • 定期后台同步
  • 推送通知

离线功能

Service Worke 通过缓存资源和拦截网络请求来提供离线功能,这些请求可以与先前缓存的资源一起使用,而不是重新请求服务器。

我们可以从中得出两个步骤:

  • 预缓存
  • 从缓存中处理请求

这两个步骤都利用了Cache API,它由 Web Workers 和浏览器使用,并且为我们提供了用于网络请求的存储机制。

对 Web 和服务工作人员上下文的 localStorage 访问被阻止,以防止并发性问题。作为一种替代方案,IndexedDB 可以用于存储大量数据。

预缓存

预缓存是一个术语,描述了在 Service Worker 处于激活状态之前下载和缓存文件。 它是在 Service Worker 生命周期的“install ”步骤中完成的。 一旦 Service Worker 处于激活状态,它将准备为缓存中的文件提供服务。

通常,我们要缓存 Application Shell

서비스워커에 대한 자세한 설명을 자바스크립트로!

서비스 워커는 이전에 기본 애플리케이션에서만 가능했던 기능 세트를 활성화합니다. 서비스 워커의 첫 번째 초안은 2014년에 출시되었으며 현재 모든 주요 브라우저에서 이를 지원합니다.

이미 지적한 정의처럼 🎜Service Worker🎜는 네트워크 프록시입니다. 즉, 페이지 내의 모든 네트워크 요청을 제어할 수 있으며 캐시된 응답을 사용하도록 프로그래밍할 수 있습니다. 🎜🎜서비스 워커 기능🎜
  • 웹사이트는 HTTPS를 사용해야 합니다. 디버깅을 위해 로컬 개발 환경을 사용하는 것 외에도(예: 도메인 이름에 localhost 사용)
  • 브라우저 백그라운드에서 실행하면 열린 범위 내에서 모든 페이지 요청을 제어할 수 있습니다.
  • 별도의 범위, 별도의 실행 환경 및 실행 스레드
  • 페이지 DOM을 작동할 수 없습니다. 하지만 이벤트 메커니즘을 통해 처리할 수 있습니다.
🎜서비스 워커 등록 방법🎜🎜서비스 워커 등록에는 많은 코드가 필요하지 않으며 서비스 워커 코드에 대한 JS 파일만 있으면 됩니다. 일반적으로 이름은 service-worker.js🎜
self.addEventListener('install', function(event) {
  event.waitUntil(
    caches.open(currentCache.offline).then(function(cache) {
      return cache.addAll([
        '/static/images/offline.svg',
        '/static/html/offline.html',
      ]);
    });
  );
});
🎜사실 키 코드는 단 한 줄입니다: 🎜
self.addEventListener('fetch', function(event) {
  event.respondWith(
    caches.match(event.request).then(function(response) {
      return response || fetch(event.request);
    })
  );
});
🎜🎜참고: 🎜🎜🎜🎜Service Worker🎜의 등록 경로에 따라 가 결정됩니다. 범위 코드> 기본 범위입니다. 예시에서 <code>service-worker.js/sw 경로에 있습니다. 이는 서비스 워커가 /sw의 데이터만 수신한다는 의미입니다. > 경로는 기본적으로 fetch 이벤트입니다. 웹사이트의 루트 경로에 저장되면 해당 웹사이트의 모든 fetcg 이벤트가 수신됩니다. 🎜🎜범위를 변경하려면 두 번째 매개변수에 scope 범위를 설정하면 됩니다. 예제에서는 전체 사이트에 적용되는 루트 디렉터리로 변경됩니다. 🎜🎜또한 다음 사항에 유의해야 합니다. 서비스 워커에는 페이지 범위 개념이 없으며 범위 내의 모든 페이지 요청은 현재 활성화된 서비스 워커에 의해 모니터링됩니다. 🎜🎜서비스워커로 어떤 기능을 활성화할 수 있나요? 🎜🎜이 섹션에서는 몇 가지 작은 코드 예제를 포함하여 서비스 워커의 기능에 대해 더 자세히 설명하겠습니다. 🎜🎜서비스 작업자는 PWA의 핵심이기도 한 다음 기능을 활성화합니다. 🎜
  • 오프라인 기능
  • 정기 백그라운드 동기화
  • 푸시 알림

오프라인 기능

🎜Service Worke는 리소스를 캐싱하고 네트워크 요청을 가로채서 서버를 다시 요청하는 대신 이전에 캐시된 리소스와 함께 사용할 수 있는 오프라인 기능을 제공합니다. 🎜🎜이로부터 두 단계를 도출할 수 있습니다: 🎜
  • 사전 캐싱
  • 캐시에서 요청 처리
🎜두 단계 모두 Cache API를 활용합니다. 웹 작업자 및 브라우저를 통해 네트워크 요청을 위한 저장 메커니즘을 제공합니다. 🎜🎜localStorage 웹 및 서비스 워커 컨텍스트에 대한 액세스는 동시성 문제를 방지하기 위해 차단됩니다. 대안으로 IndexedDB를 사용하여 대량의 데이터를 저장할 수 있습니다. 🎜🎜🎜Precaching🎜🎜🎜🎜Precaching🎜은 서비스 워커가 활성화되기 전에 파일을 다운로드하고 캐싱하는 것을 설명하는 용어입니다. 이는 서비스 워커 수명 주기의 "install" 단계에서 수행됩니다. 서비스 워커가 활성화되면 캐시에서 파일을 제공할 준비가 됩니다. 🎜🎜일반적으로 우리는 웹 사이트를 실행하는 데 필요한 최소한의 코드 양인 Application Shell을 캐시하려고 합니다. 네이티브 앱을 개발한 경우 앱 스토어에 업로드할 코드 패키지입니다. 여기에는 필요한 모든 기본 JavaScript, HTML 및 이미지가 포함됩니다. 🎜
navigator.serviceWorker.ready.then((registration) => {
  return registration.sync.register('sync-save-document');
});
🎜🎜캐시 요청 처리🎜🎜

在此阶段,我们已经将所有应用程序代码存储在缓存中,并且Service Worker 已处于激活即运行于浏览器后台。

现在唯一缺少的是监听 fetch 事件并从缓存中返回结果。可以通过 fetch 事件可以拦截到当前作用域范围内的 http/https 请求,并且给出自己的响应。结合 Fetch API ,可以简单方便地处理请求响应,实现对网络请求的控制。

self.addEventListener('fetch', function(event) {
  event.respondWith(
    caches.match(event.request).then(function(response) {
      return response || fetch(event.request);
    })
  );
});

在本例中,我们尽可能使用缓存的内容进行响应。作为回退,我们发出一个网络请求。

这里实现了一个缓存优先降级处理的策略逻辑:监控所有 http 请求,当请求资源已经在缓存里了,直接返回缓存里的内容;否则使用 fetch API 继续请求,如果是 图片或 cssjs 资源,请求成功后将他们加入缓存中;如果是离线状态或请求出错,则降级返回预缓存的离线内容。

定期后台同步

正如在引言中已经提到的那样,Service Worker 与其他服务工作者在一个单独的线程上运行,所以即使关闭页面,它们也可以执行其代码。 此功能对于执行后台同步和提供推送通知很重要。

后台同步

用户离开页面后,后台同步通常用于同步数据。

例如,在手机上编辑文档后,我们写完会点击“保存”并离开页面。 如果在编辑文档期间连接断开,我们必须等待连接恢复才能保存文档。

后台同步的目的是解决这个问题,一旦连接重新建立,自动发送数据。

来看一个示例:

app.js

navigator.serviceWorker.ready.then((registration) => {
  return registration.sync.register('sync-save-document');
});

service-worker.js

self.addEventListener('sync', (event) => {
  if (event.tag === 'sync-save-document') {
    event.waitUntil(saveDocument());
  }
});

saveDocument是一个返回 Promise,如果被拒绝(例如由于网络问题),同步将自动重试。

要注意的一件事是,同步标记必须是唯一的。 例如,如果我要安排5个“message”类型的后台同步,则只有最后一个会通过。 因此,在这种情况下,每个标签都应具有唯一的标识符。

定期后台同步

定期后台同步解决与正常后台同步不同的问题。 该API可用于在后台更新数据,而不必等待用户。

这对很多应用程序都很有用。有了这项技术,用户可以在没有互联网连接的情况下阅读最新的新闻文章。

为了防止滥用这一功能,同步的频率取决于浏览器为每个网站设置的站点参与度分数。如果你经常打开一个网页应用,这个频率最多可以达到12个小时。

要实现此目的一个要求是,该网站已作为移动设备上的 PWA 安装并添加到主屏幕。

推送通知

Service Worker另一个类似本机的特性是推送通知。我们通常通过手机短信或社交媒体通知的形式知道它们,但它们也可以在台式电脑上使用。

Safari之外,所有主流浏览器都支持它们,而Safari对桌面应用程序有自己的实现。

要使用推送通知,需要设置一台服务器,该服务器会将通知推送给所有客户端。 由于Service Worker在后台在另一个线程上运行,因此即使页面当前未打开,用户也可以看到推送通知。

推送的实现有两步:

不同浏览器需要用不同的推送消息服务器。以 Chrome 上使用 Google Cloud Messaging<gcm></gcm> 作为推送服务为例,第一步是注册 applicationServerKey(通过 GCM 注册获取),并在页面上进行订阅或发起订阅。每一个会话会有一个独立的端点(endpoint),订阅对象的属性(PushSubscription.endpoint) 即为端点值。将端点发送给服务器后,服务器用这一值来发送消息给会话的激活的 Service Worker (通过 GCM 与浏览器客户端沟通)。

浏览器支持情况

서비스워커에 대한 자세한 설명을 자바스크립트로!

除了 Safari 和 IE/Edge,大部分现代浏览器都已经得到了支持。

总结

希望通过本文介绍基本概念和特性,可以让你更好地理解Service Worker

英文原文地址:https://felixgerschau.com/service-workers-explained-introduction-javascript-api/

作者: Felix Gerschau

译文地址:https://segmentfault.com/a/1190000027080988

想要查阅更多相关文章,请访问PHP中文网!!

위 내용은 서비스워커에 대한 자세한 설명을 자바스크립트로!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제