导航栏: 首页 评论列表

navigator.serviceWorker servicesWorkers

默认分类 2020/09/17 10:02

navigator.serviceWorker标准已日趋成熟,提速页面非常有用.

index.html代码如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <title>test service worker - online page</title>
</head>
<body>
  <div style="text-align:center; margin-top:40px; font-family:monospace;">
   <img width="100" height="40" src="/sw-test/102.jpg" alt="">
   <p>您已经连接网络...</p>
   </div>
  <script>
  // 注册 service worker
  if ('serviceWorker' in navigator) {
    navigator.serviceWorker.register('./sw.js').then(function(reg) {
      // 注册成功
      console.log('ServiceWorker registration successful with scope: ', reg.scope)
    }).catch(function(err) {
      // 注册失败
      console.log('ServiceWorker registration failed: ', err)
    })
  }
  </script>
  <img width="100" height="40" src="/sw-test/101.jpg" alt="">
  <hr>
  <img width="100" height="40" src="/sw-test/102.jpg" alt="">
  <hr>
  <img width="100" height="40" src="/sw-test/202.jpg" alt="">
</body>
</html>

sw.js代码如下:

self.addEventListener('install', function(event) {
  event.waitUntil(
    caches.open('v1').then(function(cache) {
      // 相当于Cache.add() 用于获取一个 Request 的 Response,并将 Request / Response 对象体放进指定的 Cache。注:等价于 fetch(request) + Cache.put(request, response)。
      return cache.addAll([
        '/sw-test/101.jpg'
      ]);
    })
  );
});
// 首次加载页面不会捕获fetch,需重新刷新页面才会生效,特别注意
self.addEventListener('fetch', function(event) {
  console.log('fetch url:' + event.request.url)
  var sign = event.request.url.indexOf('2.jpg') > -1
  console.log(sign)
  if (sign) {
    event.respondWith(caches.match('/sw-test/101.jpg').then(function(response) {
      console.log('fetch match 101.jpg')
      // caches.match() always resolves
      // but in case of success response will have value
      return response;
    }))
  }
  else return ''
});

console.log('sw is loaded4.')

手动Cache.put(request, response)代码如下:

self.addEventListener('install', function(event) {
  event.waitUntil(
    caches.open('v1').then(function(cache) {
      return cache.addAll([
        '/sw-test/index.html',
        '/sw-test/star-wars-logo.jpg',
        '/sw-test/gallery/bountyHunters.jpg',
        '/sw-test/gallery/myLittleVader.jpg',
        '/sw-test/gallery/snowTroopers.jpg'
      ]);
    })
  );
});

self.addEventListener('fetch', function(event) {
  event.respondWith(caches.match(event.request).then(function(response) {
    // caches.match() always resolves
    // but in case of success response will have value
    if (response !== undefined) {
      return response;
    } else {
      return fetch(event.request).then(function (response) {
        // response may be used only once
        // we need to save clone to put one copy in cache
        // and serve second one
        let responseClone = response.clone();

        caches.open('v1').then(function (cache) {
          cache.put(event.request, responseClone);
        });
        return response;
      }).catch(function () {
        return caches.match('/sw-test/gallery/myLittleVader.jpg');
      });
    }
  }));
});

参考资料:https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#devtools


>> 留言评论