谷歌都在用 PWA 你还不用?

本文作者:ivweb villainthr

sw-router

PWA 全称是 Progressive Web Apps。它的目的就是让你的网页越来越快。主要内容可以参考:PWA-cookbook。不过,它上手的难度也是有的。它本身是基于 worker 而发展出 Service Worker,所以,要使用 PWA 你就必须学会如何使用 SW,然后,SW 里面还有很多坑要踩。而其中最大的坑就是,如何处理文件资源的缓存,这个一直都是 CS 领域的心病。当然,在 SW 中,这也是有点困难的。不过,为了大家能更快的掌握 SW 这里,鄙人写了一个关于处理 fetch 事件的路由分发库 sw-router

这里也主要介绍一下它。

下载

npm install sw-router

由于是在 SW 中使用,所以一般的 CMD/ES6 模块 写法是不能用的。推荐是直接到 node_modules找到 sw-router文件夹,复制其中的index.js 到你的sw.js的工作目录。然后直接引入: importScripts('./index.js');

使用

使用 SW 缓存功能其实很简单,你不需要写啥installsyncactivate事件。因为这些和你要操作的缓存都不是直接关系。最简单就是直接监听fetch 即可。

 self.addEventListener('fetch', (event)=>{
    // doSth()
});

不过,如果你要做的是比较大业务,单单使用一个 fetch 就有点 “势单力薄”。所以,本库还是基于最小业务原则的出发点来进行创作的。

通过导入之后,sw-router 会 SW 作用域下绑定一个 Router 对象。接着,你就可以在该对象上绑定相关的路由处理。

路由绑定

利用 Router 对象进行路由绑定和 express router 类似,所以上手起来也不是特别大的问题:

 Router.get('/*.js',(event,req)=>{
  console.log('to save js files');
  // doSth()
})
.get('/*.png',(event,req)=>{
  console.log('capture PNG:' + req.toString());
  // doSth()
})
.get('/.*',(event,req)=>{
  console.log('capture others request');
  // doSth()
})

它以链式的方法,来提供 restful 形式的路由注册。常用方法有:

  • all: 监听所有方法,不论是啥,get/post/put/patch。
  • get: 监听指定 get 方法的请求。
  • post: 监听指定 post 方法的请求。
  • patch: 监听指定 patch 方法的请求。
  • put: 监听指定 put 方法的请求。

使用格式如下(5 种方法使用都一样):

Router.get('/*.js',(event,req)=>{
 ...
})

其中,event,req 参数分别为:

  • event: 为 fetch 方法的回调参数。self.addEventListener('fetch', (event)=>{ // doSth() });
  • req: 等同于 event.request

如果想对不同的路由做相同的监听,可以直接传入数组,或者通过,连接不同的内容。

get('/path','/demo',(event,req)=>{
    //
}) 

get(['/path','/demo'],(event,req)=>{
    // 
})

当然,这里不仅仅只提供了路由绑定的功能,还提供了缓存的做法。

缓存文件

缓存的方法也绑定在 Router 对象上,它的使用如下:

 Router.get('/*.js',(event,req)=>{
  console.log('to save js files');
  Router.save('test',event);
})

它的格式为: Router.save(cacheName, event);

  • cacheName: 为你缓存文件方式的文件夹的名字。你也可以理解为数据库中的 table。只是为了区分缓存文件的一个目录而已。如果你不写的话,默认为 defaultName。所以,使用方式也可以为:Router.get('/*.js',(event,req)=>{ console.log('to save js files'); Router.save(event); })
  • event: 就是你注册路由的 event 参数。直接传进去就好。

上面,大致介绍了路由注册这一块内容,但是,如果使用你注册好的路由分发系统呢?

投入生产

路由系统真正接入 SW 是通过watch 方法来进行监听的。具体使用为:

 Router.get('/*.js',(event,req)=>{
  console.log('save js files');
  Router.save('v1',event);
})
.get('/*.png',(event,req)=>{
  console.log('capture PNG:' + req.toString());
  Router.save('v1',event);
})
.get('/.*',(event,req)=>{
  console.log('capture all request');
})

self.addEventListener('fetch', function(event) {
 // start to listen
  Router.watch(event);
});

注意,watch 只能传入 event 参数,其它的就不要乱传了。

英文文档

sw-router

反馈

如果在使用库的同时,遇到什么问题,可以去 issue 提一提。鄙人一定会及时处理并回复。

作者

villainhr

License

ISC

原文链接:http://www.ivweb.io/topic/592ec04009439b0640aefbc0

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏刘望舒

Gradle入门前奏

在文章为什么现在要用Gradle?中,我们学习了常见的构建工具,以及Gradle与这些构建工具相比有那些不同的特性。这一篇文章我们接着来学习Gradle入门需要...

822
来自专栏前端小吉米

谷歌都在用 PWA 你还不用?

1485
来自专栏程序猿DD

Spring Boot开发Web应用

《SpringBoot快速入门》 中我们完成了一个简单的RESTful Service,体验了快速开发的特性。在留言中也有朋友提到如何把处理结果渲染到页面上。那...

1946
来自专栏JavaQ

深入Spring Boot (十二):集成JSP

话不多说,直接上代码。依赖管理pom.xml,需要添加servlet和嵌入式tomcat运行jsp需要的jar,详细依赖配置如下:

862
来自专栏电光石火

Gradle安装使用

简单介绍 Gradle是一个好用的构建工具 使用它的原因是 1、配置相关依赖代码量少,不会像maven一样xml过多 2、打包编译测试发布都有,而且使用起来方便...

2904
来自专栏软件工程师成长笔记

SSM框架——使用MyBatis Generator自动创建代码

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google c...

642
来自专栏飞雪无情的博客

java.lang.UnsupportedOperationException android.view.GLES20Canvas.clipPath

今天自定义控件使用Canvas绘图的时候遇到的这个错误,看错误的描述,是不支持这个clipPath方法的。而且在2.3的机器上没有问题,是一部4.0的机器报了这...

733
来自专栏WindCoder

wordpress页面异常导致本地路径泄漏

之前用360检测到如下错误,类似的出现过好几次了,暂且记录下来,路径用的其他地方的,但问题及解决办法是一样的。

641
来自专栏我是极客人

程序算法|PHP、安卓、C++程序代码交流

使用android studio的安卓开发者可能发现它和eclipse+ADT大同小异,个人用完android studio之后发现android studio...

781
来自专栏偏前端工程师的驿站

让VIM支持Python2 by update-alternatives

前言  Ubuntu 16+中$ sudo apt install vim所安装的vim只支持Python3,但很多插件如YCM和powerline均需要Pyt...

2148

扫码关注云+社区