博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
service worker之cache实践--sw-precache
阅读量:6199 次
发布时间:2019-06-21

本文共 2021 字,大约阅读时间需要 6 分钟。

Progressive web application是谷歌推出的一种渐进式应用,我觉得其实PWA是一种非常具有发展前景的技术。首先,PWA是由谷歌推出的,而且跨平台,PWA可以给你类似于原生APP的体验,通过service worker,你可以将资源缓存到本地。但是,PWA再国内一直都是不温不火,主要有好几个原因:一是因为国内的浏览器环境比较复杂,而PWA一般只是能够在chrome浏览器得到较好的支持。虽然chrome在桌面端占据了很大比例,但是在移动端还是一般般,普通的用户不一定会去安装Chrome。二是safari浏览器对于PWA的支持不是很完美,service worker目前还是没有得到支持的。

但是我是觉得PWA还是很好的,值得开发者们进一步探索。有一点偏题了,今天要讨论的其实是PWA里面service worker资源的缓存问题。主要问题的背景是这样的,我有一个的PWA,可以支持离线使用,有兴趣的同学可以尝试看看。我遇到一个问题,就是每次我更新之后代码之后,加入我的PWA被添加到主屏之后,这个APP的代码就没有更新,必须删除后重新重浏览器中添加到主屏。一开始我以为是PWA的问题,后来竟别人提醒,桌面上的APP其实也就是网站的链接。我这才恍然大悟,问题是因为我的servicer worker里面的缓存策略有问题。因为我的APP通过service worker来缓存资源,包括js,css以及图片文件,所以始终是从缓存中加载资源,所以我远程代码更新后,这个APP的代码却没有得到更新。OK,拿代码说话,我一开始的代码是:

var cacheName = 'subway';var filesToCache = [    '/',    'index.html',    'image/transfer.png',    'dist/alloy_finger.js',    'app.css'];self.addEventListener('install', function(e) {    console.log('service worker install');    e.waitUntil(caches.open(cacheName).then(function(cache) {        console.log('serviceworker caching app shell');        return cache.addAll(filesToCache);    }));});

可以看出我们在install事件后通过在cache里面加载文件,所以我们必须选择一种合适的策略能够让我们的APP在代码更新之后去请求新的代码呢?

Google其实在PWA推出的过程中也给出了很多有用的技术。比如以及,以及最近正在发展过程中的。这里,我主要使用的是sw-precache来更新我的service worker策略。

sw-precache也是NODE中的一个模块,可以通过npm install sw-precache来进行安装。sw-precache可以配合多个工具使用,这里我主要介绍一下如何配合gulp来使用。我们通过利用sw-precache来帮助我们生成sw-precache。饿了么的huangxuan在medium写了一篇来渗入地介绍sw-precache,这篇文章写的不错,但是却是在墙外,主要是介绍sw-precache的工作方式。我就谈一下我对sw-precache的理解把,以一个gulpfile的一段代码为例:

gulp.task('generate-sw', function(callback) {    var path = require('path');    var swPrecache = require('sw-precache');    swPrecache.write(path.join('sw.js'), {        staticFileGlobs: [            'app.js',            'dist/alloy_finger.js',            'dist/app.css',            'image/*.{png}',            'index.html',            '/'        ]    }, callback)})

我们通过利用sw-precache来生成。主要的方式是检测你在staticFileGlobs里面的文件有没有发生变化,如果发生变化就会重新生成hash码,从而能够使得APP在代码更新之后向远程请求新的代码。

这篇文章可能只是很小的一点,关于service worker的使用还有很多东西值得学习,欢迎关注我的共同探讨。

转载地址:http://znnca.baihongyu.com/

你可能感兴趣的文章
jsp九大内置对象
查看>>
制作一款微信表情
查看>>
高仿Instagram 页面效果android特效
查看>>
jsonp跨域访问+AES,RSA加密
查看>>
我的友情链接
查看>>
Juniper 基于路由的×××
查看>>
OSI七层模型03——数据封装
查看>>
UMail轻松搭建linux邮件服务器(一体盘安装)
查看>>
HDU - 2018 - 母牛的故事(dp)
查看>>
51nod挑的部分5级题
查看>>
基于matlab的fft变换中参数的设置
查看>>
如何查找JSP页面中的错误
查看>>
2016 年总结
查看>>
Python学习开始
查看>>
VC6.0之Debug调试总结
查看>>
面向对象设计:共性VS个性-------继承的粒度和聚合的粒度以及类的重构
查看>>
Android应用程序消息处理机制(Looper、Handler)分析(4)
查看>>
C++ 类成员的构造和析构顺序
查看>>
将String转化成Stream,将Stream转换成String
查看>>
POJ-1011 Sticks
查看>>