HTML5离线缓存
HTML5离线缓存
HTML5离线缓存
HTML5的离线存储是基于一个新建的.manifest
文件的,通过这个文件上的解析清单
离线存储资源,这些资源就会像cookie一样被存储了下来,之后当网络在处于离线状态下时,浏览器会通过离线存储的数据进行页面展示。
一、HTML5离线缓存优点
1、离线浏览 – 用户可在应用离线时使用它们
2、速度 – 已缓存资源加载得更快
3、减少服务器负载 – 浏览器将只从服务器下载更新过或更改过的资源。
二、HTML5离线缓存基本流程
第一次正确配置app cache后,当我们再次访问该应用时,浏览器会首先检查manifest文件是否有变动,如果有变动就会把相应的变得跟新下来,同时改变浏览器里面的app cache,如果没有变动,就会直接把app cache的资源返回。
三、离线缓存与传统浏览器缓存区别
1、离线缓存是针对整个应用,浏览器缓存是单个文件
2、离线缓存断网了还是可以打开页面,浏览器缓存不行
3、离线缓存可以主动通知浏览器更新资源
四、manifest文件的写法
CACHE MANIFEST
#上面一句必须
#v1.0.0
#需要缓存的文件
CACHE:
a.js
b.css
#不需要缓存的文件
NETWORK:
*
#无法访问页面
FALLBACK:
404.html
五、manifest文件的格式说明
1、CACHE MANIFEST(必须)
(1)、为固定格式,必须写在最前面
(2)、以#号开头的是注释,一般会在第二行写个版本号,用来在缓存的文件更新时,更改manifest的作用,可以是版本号,时间戳或者md5码等等。
2、CACHE(必须)
(1)、标识出哪些文件需要缓存,可以是相对路径也可以是绝对路径。
(2)、当 manifest 文件加载后,浏览器会从网站的根目录下载这些文件。然后,无论用户何时与因特网断开连接,这些资源依然是可用的。
3、NETWORK(可选)
(1)、这一部分是要绕过缓存直接读取的文件,需要与服务器连接,且不会被缓存
(2)、使用通配符”*”,表示所有其他资源/文件都需要因特网连接
4、NETWORK(可选)
(1)、指定了一个后备页面,当资源无法访问时,浏览器会使用该页面。该段落的每条记录都列出两个 URI—第一个表示资源,第二个表示后备页面。两个 URI 都必须使用相对路径并且与清单文件同源。
(2)、例如
如果无法建立因特网连接,则用 “404.html” 替代 /html5/ 目录中的所有文件
FALLBACK:/html5/ /404.html
如果无法建立因特网连接,则用 “404.html” 替代所有文件
FALLBACK:*.html /404.html
六、如何更新HTML5离线缓存
如下三种方式,可以更新缓存:
1、更新manifest文件
(1)、给manifest添加、修改或删除,都可更新缓存 。
(1)、如果我们更改了js,而没有新增或删除,前面例子中注释中的版本号,可以很好的用来更新manifest文件。
2、通过javascript操作
html5中引入了js操作离线缓存的方法,下面的js可以手动更新本地缓存。
window.applicationCache.update();
3、清除浏览器缓存
如果用户清除了浏览器缓存(手动或用其他一些工具)都会重新下载文件
七、对Manifest 文件常用的事件
1、核心是applicationCache对象,有个status属性,表示应用缓存的当前状态:
0(UNCACHED) : 无缓存, 即没有与页面相关的应用缓存
1(IDLE) : 闲置,即应用缓存未得到更新
2 (CHECKING) : 检查中,即正在下载描述文件并检查更新
3 (DOWNLOADING) : 下载中,即应用缓存正在下载描述文件中指定的资源
4 (UPDATEREADY) : 更新完成,所有资源都已下载完毕
5 (IDLE) : 废弃,即应用缓存的描述文件已经不存在了,因此页面无法再访问应用缓存
2、 相关的事件
表示应用缓存状态的改变:
checking : 在浏览器为应用缓存查找更新时触发
error : 在检查更新或下载资源期间发送错误时触发
noupdate : 在检查描述文件发现文件无变化时触发
downloading : 在开始下载应用缓存资源时触发
progress:在文件下载应用缓存的过程中持续不断地下载地触发
updateready : 在页面新的应用缓存下载完毕触发
cached : 在应用缓存完整可用时触发
八、HTML5离线缓存使用注意事项
(1)、manifest文件的mime-type必须是 text/cache-manifest类型
(2)、站点离线存储的容量限制是5M
(3)、如果manifest文件,或者内部列举的某一个文件不能正常下载,整个更新过程将视为失败,浏览器继续全部使用老的缓存
(4)、引用manifest的html必须与manifest文件同源,在同一个域下
(5)、在manifest中使用的相对路径,相对参照物为manifest文件
(6)、CACHE MANIFEST字符串应在第一行,且必不可少
(7)、系统会自动缓存引用清单文件的 HTML 文件
(8)、manifest文件中CACHE则与NETWORK,FALLBACK的位置顺序没有关系,如果是隐式声明需要在最前面
(9)、FALLBACK中的资源必须和manifest文件同源
(10)、当一个资源被缓存后,该浏览器直接请求这个绝对路径也会访问缓存中的资源。
(11)、站点中的其他页面即使没有设置manifest属性,请求的资源如果在缓存中也从缓存中访问
(12)、当manifest文件发生改变时,资源请求本身也会触发更新
- html5的新特性
- html5自定义字体图标(HTML5给汉字加拼音收起展开组件的实现代码)
- HTML5 audio标签
- Html5新增的标签
- html5 web技术(html5视频常用API接口的实战示例)
- html元素和属性的区别(HTML5 HTMLCollection和NodeList的区别详解)
- html5基本标签详解(HTML5 通过Vedio标签实现视频循环播放的示例代码)
- html5 data属性
- html5 spellcheck属性
- HTML5 <abbr>标签
- HTML5中新增的Input类型
- html5实时通讯(使用Html5 Stream开发实时监控系统)
- HTMl5 sessionStorage和localStorage
- html5底部组件(HTML5 Blob对象的具体使用)
- html5标签图片(HTML5图片层叠的实现示例)
- html5本地存储功能(利用Node实现HTML5离线存储的方法)
- 关于队徽 你了解这些么 二(关于队徽你了解这些么)
- 冬天来了手脚冰凉 真不是因为上辈子你是折翼的天使(冬天来了手脚冰凉)
- 0 1 岁婴儿最强作息指南,照着做养出天使宝宝(01岁婴儿最强作息指南)
- 沪上这16所高校 萌新 礼包开箱 哪一款让你心动(沪上这16所高校萌新)
- 她救了被绑架的他,而这一切竟是一场阴谋...(她救了被绑架的他)
- 冬季养殖这6种阴生植物,方便又好养,你家有么(冬季养殖这6种阴生植物)
热门推荐
- nginx 怎么避免options请求(详解nginx 的 default_server 定义及匹配规则)
- dedecms标签分类(Dedecms程序SEO常用的列表标签调用代码集合 dedecms优化)
- CSS3动画属性animation
- dedecms分页样式(dedecms列表页文章摘要字数的设置方法)
- 云服务器实例一直在停止(云服务器重启原因有哪些?)
- windows安全策略设置sqlserver(SQLServer 错误: 15404,无法获取有关 Windows NT 组/用户 WIN-8IVSNAQS8T7Administrator 的信)
- docker容器的三大组件(docker容器下配置jupyter notebook的操作)
- css怎么让div整体居中(CSS实现DIV居中的三种方法)
- vue如何获取元素(vue第一次获取不到元素的解决方法记录)
- dedecms如何提高网站权重(dede网站内容页如何调取栏目页标题及关键字组合为seo标题)