AppCache 与 ServiceWorkers
先上两个链接(详细解说请见):
下面上菜(例子),鉴于AppCache已经从 Web 标准中删除, 先说 ServiceWorkers:
ServiceWorkers, 在html中直接调用了 navigator.serviceWorker.register.
这里有个要特别注意的:
- serviceWorker 的 js 文件所在的目录即为最大的 scope
- 在 scope 下的文件及这些文件及其加载的文件(如index.html在scope下,但加载了第三方图片)都会被 serviceWorker 缓存
- 故而 serviceWorker 文件一定要在 html 文件的同一个目录或者父级目录中, 否则无法缓存 html 文件, 即会导致无法离线访问!
| 1 | 
 | 
test-serviceworker.js 文件的内容
该文件一定要在 html 文件的同一个目录或者父级目录中, 否则无法缓存 html 文件, 即会导致无法离线访问!1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33self.addEventListener('install', function(event) {
  event.waitUntil(
    caches.open('v2').then(function(cache) {
      return cache.addAll([
        '/html/test-serviceworker.html',
        '/css/test-manifest.css'
      ]);
    })
  );
});
self.addEventListener('fetch', function(event) {
  event.respondWith(caches.match(event.request).then(function(response) {
    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('v2').then(function (cache) {
          cache.put(event.request, responseClone);
        });
        return response;
      }).catch(function (err) {
        console.log(err);
        // return caches.match('/sw-test/gallery/myLittleVader.jpg');
      });
    }
  }));
});
AppCache, 我用 nodejs(koa) 写的appcache文件:
| 1 | router.get('/cache.appcache', async (ctx, next) => { | 
process.env.UPDATE_MANIFEST 是一个数字,用来更新缓存文件.
下面的代码将该数字转为对应数量的空格字符串:
| 1 | const num = process.env.UPDATE_MANIFEST; | 
总结一下啊,不知道你有没有发现, ServiceWorkers 基本是前端的活, AppCache 基本是后端的活.
单纯这一条就让我觉得 ServiceWorkers 比 AppCache 更优秀! 不过 ServiceWorkers 在 Safari 浏览器上还不受支持.
