PWA 学习笔记(五)
离线与缓存
资源请求的拦截代理:
1、资源请求的判断:
(1)fetch 事件会拦截页面上所有的网络资源请求,但我们通常只对部分资源请求进行处理,
其余的请求会继续走浏览器默认的资源请求流程
(2)fetch 事件回调参数的 event.request 属性描述了当前被拦截的资源请求,可以通过它来进行判断分类。
event.request 是 Request 对象的实例,包含了资源请求的 URL、请求模式、请求头等全部信息
(3)一般情况下,资源请求的判断可以通过对 event.request.url 进行匹配来实现
// 全等匹配
if (event.request.url === 'http://127.0.0.1:8080/data.txt') {
// 匹配成功
} // 正则匹配
if (/\/data\.txt/.test(event.request.url)) {
// 匹配成功
} // 借助 URL 进行匹配
let url = new URL(event.request.url)
if (
url.hostname === '127.0.0.1' &&
url.port === '8080' &&
url.pathname === '/data.txt'
) {
// 匹配成功
}
注:正则表达式可参考我之前的随笔 https://www.cnblogs.com/lemonyam/p/10649030.html
2、资源请求的响应:
(1)fetch 事件回调参数的方法 event.respondWith(r) 可以指定资源请求的响应结果
(2)respondWith(r) 方法的参数 r 可以是一个 Response 对象实例,也可以是一个 Promise 对象,这个 Promise 对象
在异步执行完成的时候同样需要 resolve 返回一个 Response 对象实例作为请求的响应结果
// 直接返回 Response 对象
event.respondWith(new Response('Hello World!')) // 等待 1 秒钟之后异步返回 Response 对象
event.respondWith(new Promise(resolve => {
setTimeout(() => {
resolve(new Response('Hello World!'))
}, 1000)
}))
3、异步资源请求响应:
(1)event.respondWith 方法与 install、activate 事件回调参数中的 event.waitUntil 类似,
起到了扩展延长 fetch 事件生命周期的作用
(2)在 fetch 事件回调同步执行完毕之前如果没有调用 event.respondWith(r) 指定资源响应结果,
那么就会进入浏览器默认的资源请求流程当中
// 错误用法
self.addEventListener('fetch', event => {
if (event.request.url === 'http://127.0.0.1:8080/data.txt') {
setTimeout(() => {
event.respondWith(new Response('Hello World!'))
}, 1000)
}
}) // 正确用法 // 等待 1 秒钟之后异步返回 Response 对象
event.respondWith(new Promise(resolve => {
setTimeout(() => {
resolve(new Response('Hello World!'))
}, 1000)
}))
4、资源请求响应的错误处理:
(1)当使用了 event.respondWith 指定资源响应之后,无论是以同步还是异步的方式,最终都需要返回 Response 对象
(2)在调用 event.respondWith 的时候,需要主动捕获并处理错误、异常返回结果
5、资源请求与响应操作的管理:
在 fetch 事件回调当中主要进行着资源请求匹配和响应结果返回的操作,可以把这个过程当做一个路由分发的问题,
因此我们可以封装一个 Router 类来实现对路由的匹配规则和操作分发的统一管理
本地存储管理:
1、因为基于性能上的考虑,Service Worker 在设计标准时就要求了任何耗时操作必须异步实现。这也导致了在
Service Worker 作用域下能够使,目前只有 Cache API 和 IndexedDB,因为目前只有二者在功能实现上全部
采用了异步形式,而其他诸如 localStorage 属于同步方法,因此无法在 Service Worker 中使用
2、Cache API 与 IndexedDB 的应用场景:
(1)Cache API 适用于请求响应的本地存储:为资源请求与响应的存储量身定做的,它采用了键值对的数据模型
存储格式,以请求对象为键、响应对象为值,正好对应了发起网络资源请求时请求与响应一一对应的关系
(2)IndexedDB 是一种非关系型数据库,它的存储对象主要是数据,比如数字、字符串、Plain Objects、Array 等,
以及少量特殊对象比如 Date、RegExp 等等,对于 Request、Response 这些是无法直接被 IndexedDB 存储的
(3)Cache API 和 IndexedDB 在功能上是互补的。在设计本地资源缓存方案时通常以 Cache API 为主,
但在一些复杂的场景下,Cache API 这种请求与响应一一对应的形式存在着局限性,因此需要结合上功能上更为
灵活的 IndexedDB,通过 IndexedDB 存取一些关键的数据信息,辅助 Cache API 进行资源管理
3、缓存注意项:
(1)本地存储空间是有限的:浏览器提供了 StorageEstimate API 去查询当前缓存空间的使用情况
navigator.storage.estimate()
.then(estimate => {
// 设备为当前域名所分配的存储空间总大小
console.log(estimate.quota)
// 当前域名已经使用的存储空间大小
console.log(estimate.usage)
})
(2)资源的存取过程可能会失败:应该随时做好存取失败时的异常捕获与降级方案,确保程序运行时不会出错
(3)存储的资源可能会过期:要及时做好资源的更新和旧资源的清理工作
PWA 学习笔记(五)的更多相关文章
- C#可扩展编程之MEF学习笔记(五):MEF高级进阶
好久没有写博客了,今天抽空继续写MEF系列的文章.有园友提出这种系列的文章要做个目录,看起来方便,所以就抽空做了一个,放到每篇文章的最后. 前面四篇讲了MEF的基础知识,学完了前四篇,MEF中比较常用 ...
- (转)Qt Model/View 学习笔记 (五)——View 类
Qt Model/View 学习笔记 (五) View 类 概念 在model/view架构中,view从model中获得数据项然后显示给用户.数据显示的方式不必与model提供的表示方式相同,可以与 ...
- java之jvm学习笔记五(实践写自己的类装载器)
java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类 ...
- Learning ROS for Robotics Programming Second Edition学习笔记(五) indigo computer vision
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...
- Typescript 学习笔记五:类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- ES6学习笔记<五> Module的操作——import、export、as
import export 这两个家伙对应的就是es6自己的 module功能. 我们之前写的Javascript一直都没有模块化的体系,无法将一个庞大的js工程拆分成一个个功能相对独立但相互依赖的小 ...
- muduo网络库学习笔记(五) 链接器Connector与监听器Acceptor
目录 muduo网络库学习笔记(五) 链接器Connector与监听器Acceptor Connector 系统函数connect 处理非阻塞connect的步骤: Connetor时序图 Accep ...
- python3.4学习笔记(五) IDLE显示行号问题,插件安装和其他开发工具介绍
python3.4学习笔记(五) IDLE显示行号问题,插件安装和其他开发工具介绍 IDLE默认不能显示行号,使用ALT+G 跳到对应行号,在右下角有显示光标所在行.列.pycharm免费社区版.Su ...
- Go语言学习笔记五: 条件语句
Go语言学习笔记五: 条件语句 if语句 if 布尔表达式 { /* 在布尔表达式为 true 时执行 */ } 竟然没有括号,和python很像.但是有大括号,与python又不一样. 例子: pa ...
随机推荐
- [TimLinux] Python Django与WSGI的简介
1. Web应用 web应用的最原始的访问流程: 客户端发送HTTP请求: 服务端接收到请求,生成一个HTML文档: 服务端将构造HTTP响应,包含:响应头(响应码.键值对).响应体(HTML文档) ...
- hdu5969最大的位或
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5969 题意:给定自然数l和r ,选取2个整数x,y,满足l <= x <= y <= r ...
- Linux中sed基础
sed是一种流编辑器,它是文本处理中非常重要的工具,能够完美的配合正则表达式使用,功能不同凡响.处理时,把当前处理的行存储在临时缓冲区中,称为"模式空间"(pattern spac ...
- rsync服务的讲解
第2章 rsync备份服务器的搭建 2.1 rsync备份服务器的概念 2.1.1 概念 rsync服务器对网站服务器数据进行备份(防止数据丢失和数据进行恢复) rsync服务器对网站服务器数据进行对 ...
- eclipse右下角一直在loading jar文件,如何关闭?
通常导入项目的时候,右下角会显示download一些jar包或者其它内容,速度非常慢,如果你长得很帅很美可能更拖网速,最后可能会超时报错. 大招来了!!! 首先,打开windows->pre ...
- Spring Cloud第十篇 | 分布式配置中心Config
本文是Spring Cloud专栏的第十篇文章,了解前九篇文章内容有助于更好的理解本文: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 Spring Clo ...
- NodeJS4-2静态资源服务器实战_实现获取文件路径
实例2 : 实现获取文件路径,判断是文件还是文件夹,如果是文件夹就显示里面的列表文件,如果是文件就显示里面的内容 defaultConfig.js module.exports={ root:proc ...
- CCF-CSP题解 201709-3 JSON查询
要求写一个小程序完成JSON查询的功能. 查询dfs就好了. 存储JSON对象用图(树)就好,把\(<key[],type,val[]>\)作为节点,然后又是字符串处理了. 其实就是个简化 ...
- django基础之day09,创建一个forms表单组件进行表单校验,知识点:error_messages,label,required,invalid,局部钩子函数,全局钩子函数, forms_obj.cleaned_data,forms_obj.errors,locals(), {{ forms.label }}:{{ forms }},{{ forms.errors.0 }}
利用forms表单组件进行表单校验,完成用户名,密码,确认密码,邮箱功能的校验 该作业包含了下面的知识点: error_messages,label,required,invalid,局部钩子函数,全 ...
- Python文件的操作函数的使用
字符编码 二进制和字符之间的转换过程 --> 字符编码 ascii,gbk,shit,fuck 每个国家都有自己的编码方式 美国电脑内存中的编码方式为ascii ; 中国电脑内存中的编码方式为g ...