CDN服务工作者

时间:2016-06-29 19:01:05

标签: javascript service-worker sw-precache

我尝试使用sw-precache设置服务工作者来缓存来自CDNJS的资产以供脱机使用。不幸的是,这似乎并没有起作用。这就是我到目前为止所拥有的:

index.html中加载任何脚本之前:

<script type='text/javascript'>
  if ('serviceWorker' in navigator) {
    navigator.serviceWorker.register('/js/service_worker.js')
      .then(function() {
        console.log("Service Worker Registered")
      })
  }
</script>

这是我用来生成服务工作者的Gulp任务:

const config = require('../config')
const gulp = require('gulp')
const swPrecache = require('sw-precache')

gulp.task('serviceWorker', (callback) => {

  swPrecache.write(config.build.serviceWorker, {
    runtimeCaching: [
      {
        urlPattern: /^https:\/\/cdnjs\.cloudflare\.com/,
        handler: 'networkFirst'
      }
    ]
  }, callback)
})

当我运行应用程序时,我看到Service Worker Registered已登录到控制台。但是,如果我断开我的wifi,应用程序无法加载脚本。我做错了什么?

Errors

2 个答案:

答案 0 :(得分:4)

您正在某个JS路径/js/service_worker.js注册服务工作者。这里,scope将服务工作者限制为仅控制该路径/js/下的指定内容。

I suggest you to register service worker at root level,即www.example.com/,您就可以控制在此域下投放的所有网页。

答案 1 :(得分:0)

我认为您的问题在于范围

服务工作者只有它所在目录的最大范围。也就是说,它无法加载从其结构或其上方的位置拉出的文件/请求/响应,仅在下面。

因此,如果您将服务工作者的位置更改为Web项目的根目录,则应触发fetch事件,并且您的资产应从缓存加载。

这里将在“注册服务工作者”部分进一步说明。 https://developers.google.com/web/fundamentals/getting-started/primers/service-workers