首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >谷歌都在用 PWA 你还不用?

谷歌都在用 PWA 你还不用?

原创
作者头像
腾讯IVWEB团队
发布于 2017-07-03 08:37:08
发布于 2017-07-03 08:37:08
1.4K00
代码可运行
举报
运行总次数:0
代码可运行

本文作者: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 即可。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 self.addEventListener('fetch', (event)=>{
    // doSth()
});

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

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

路由绑定

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 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 种方法使用都一样):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Router.get('/*.js',(event,req)=>{
 ...
})

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

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
get('/path','/demo',(event,req)=>{
    //
}) 

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

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

缓存文件

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 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 方法来进行监听的。具体使用为:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 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

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

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
设计模式学习笔记(三)简单工厂、工厂方法和抽象工厂之间的区别
设计模式中的工厂模式(Factory Design pattern)是一个比较常用的创建型设计模式,其中可以细分为三种:简单工厂(Simple Factory)、工厂方法(Factory Method)和抽象工厂(Abstract Factory)。那么三者有什么区别呢?先说结论:
归思君
2023/10/16
3.8K0
设计模式学习笔记(三)简单工厂、工厂方法和抽象工厂之间的区别
Java设计模式:工厂模式之简单工厂、工厂方法、抽象工厂(三)
在软件设计中,工厂模式是一种常见的设计模式,它提供了一种创建对象的最佳方式。通过工厂模式,我们可以将对象的创建逻辑与使用逻辑分离,降低代码的耦合度,提高系统的可扩展性和可维护性。
公众号:码到三十五
2024/03/19
2140
Java 工厂设计模式详解
工厂设计模式(Factory Pattern)是最常用的设计模式之一,属于创建型模式。其核心思想是通过引入一个工厂类来实例化对象,而不是直接在客户端代码中使用 new 关键字来创建对象。这种方式能够将对象的创建过程封装起来,使得代码更加灵活、可扩展、易于维护。
HandsomeYo
2025/04/03
1200
Java 工厂设计模式详解
浅谈设计模式——工厂模式
  这是工厂模式中最简单的一种,专门定义一个类来负责创建其他类的实例,同时被创建的实例具有共同的父类。
huofo
2022/03/17
1.1K0
浅谈设计模式——工厂模式
23种设计模式(2):工厂方法模式
定义:定义一个用于创建对象的接口,让子类决定实例化哪一个类,工厂方法使一个类的实例化延迟到其子类。
全栈程序员站长
2022/07/09
2030
23种设计模式(2):工厂方法模式
JAVA设计模式2:工厂方法模式,将对象的实例化过程封装在子类
本文讲解了 Java 设计模式中的工厂方法模式,并给出了样例代码,工厂方法模式是一种创建型设计模式,它提供了一种将对象的实例化过程封装在子类中的方式。
Designer 小郑
2023/08/02
3620
JAVA设计模式2:工厂方法模式,将对象的实例化过程封装在子类
设计模式之抽象工厂模式
抽象工厂模式(Abstract Factory),是23种设计模式之一。DP中是这么定义抽象工厂模式的:
端碗吹水
2020/09/23
5100
设计模式之抽象工厂模式
设计模式-简单工厂
使用工厂方法模式可以应付我们遇到的大部分需求,当产品种类变多的时候,这个时候会出现大量的工厂类,怎么解决这个问题?可以对产品树上类似的种类使用简单工厂模式来实现。也就是说 工厂方法+简单工厂= 抽象工厂。
王小明_HIT
2020/11/11
3530
聊聊设计模式之工厂方法模式
定义:定义一个用于创建对象的接口,让子类决定实例化哪一个类,工厂方法使一个类的实例化延迟到其子类。
Bug开发工程师
2018/07/23
3730
聊聊设计模式之工厂方法模式
设计模式:抽象工厂方法模式
今天说一下抽象工厂模式:提供一个接口,用于创建相关或依赖对象的家族,而不需要明确指定具体类。 抽象工厂允许客户使用抽象的接口来创建一组相关的产品,而不需要知道实际产出的具体产品是什么,这样一来,客户就
lpxxn
2018/01/31
4790
设计模式:抽象工厂方法模式
一篇文章带你读懂设计模式之工厂模式
假设Pizza有不同口味的,比如:有北京奶酪Pizza 北京的胡椒Pizza;或者是伦敦的奶酪Pizza 伦敦的胡椒Pizza
@派大星
2023/06/28
1920
一篇文章带你读懂设计模式之工厂模式
设计模式之工厂模式
将选择实现类、创建对象统一管理和控制。从而将调用者跟我们的实现类解耦。 实例化对象,用工厂方法代替new操作。
时间静止不是简史
2020/07/24
4400
设计模式之工厂模式
最全工厂设计模式案例详解,不服来辩!
工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一,今天我们一起来彻底解析一下它。
Java极客技术
2022/12/02
4450
最全工厂设计模式案例详解,不服来辩!
详解设计模式:工厂方法模式
工厂方法模式,又称工厂模式、多态工厂模式和虚拟构造器模式,通过工厂父类定义负责创建产品的公共接口,子类负责生产具体对象。
栗筝i
2022/12/02
5130
详解设计模式:工厂方法模式
简单工厂模式、工厂模式、抽象工厂模式比较
设计模式已经经历了很长一段时间的发展,它们提供了软件开发过程中面临的一般问题的最佳解决方案。学习这些模式有助于经验不足的开发人员通过一种简单快捷的方式来学习软件设计。
良知犹存
2021/03/06
1.1K0
简单工厂模式、工厂模式、抽象工厂模式比较
图解Java设计模式之工厂模式
看一个具体的需求 看一个披萨的项目 :要便于披萨种类的扩展,要便于维护 1)披萨的种类很多(比如GreekPizz、CheesePizz等) 2)披萨的制作有prepare、bake、cut、box 3)完成披萨店订购功能。 传统的方式 :
海仔
2020/03/18
5020
图解Java设计模式之工厂模式
C++一分钟之-设计模式:工厂模式与抽象工厂
在软件工程中,设计模式是一种通用的解决方案,用于解决常见的设计问题。工厂模式和抽象工厂模式是创建型设计模式中的两个重要成员,它们帮助我们创建对象而不需要暴露创建逻辑,同时使系统在不修改现有代码的情况下可以扩展。
Jimaks
2024/07/14
1050
23种设计模式之工厂模式
现实生活中,原始社会自给自足(没有工厂),农耕社会小作坊(简单工厂,民间酒坊),工业革命流水线(工厂方法,自产自销),现代产业链代工厂(抽象工厂,富士康)。
Java技术债务
2022/09/26
3570
23种设计模式之工厂模式
C++一分钟之-设计模式:工厂模式与抽象工厂
在软件工程中,设计模式是一种通用的解决方案,用于解决常见的设计问题。工厂模式和抽象工厂模式是创建型设计模式中的两个重要成员,它们帮助我们创建对象而不需要暴露创建逻辑,同时使系统在不修改现有代码的情况下可以扩展。
Jimaks
2024/07/15
1090
简单工厂模式
简单工厂模式(Simple Factory Pattern)是一种创建型设计模式,用于创建对象的实例。通过一个工厂类来决定实例化哪一个具体类,降低客户端与具体类之间的耦合。
码事漫谈
2024/12/20
960
简单工厂模式
推荐阅读
相关推荐
设计模式学习笔记(三)简单工厂、工厂方法和抽象工厂之间的区别
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验