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 canvas touch(html5 canvas手势解锁源码分享)
- html5添加背景(Html5实现首页动态视频背景的示例代码)
- 微信html隐藏功能(使用Html5多媒体实现微信语音功能)
- HTML5中新增的Input类型
- html5隐藏数字(HTML5去掉输入框type为number时的上下箭头的实现方法)
- html5如何使用svg(将SVG图引入到HTML页面的实现)
- h5实现弹出悬浮窗(Html5监听手机摇一摇事件的实现)
- html5标签怎么做(html5用video标签流式加载的实现)
- html5图片上下滚动(HTML5 图片悬停放大的实现代码示例)
- html5图片做背景代码(Html5之webcoekt播放JPEG图片流)
- html5新的表单元素新的特性(HTML5表单验证特性知识点小结)
- html5+css样式代码(详解HTML5中CSS外观属性)
- html5页面强制刷新(移动端html5判断是否滚动到底部并且下拉加载)
- html5能取数据库吗(HTML5 客户端数据库简易使用:IndexedDB)
- html5炫酷代码(HTML5实现视频弹幕功能)
- 参考文献里期刊名称的写法,你知道吗(参考文献里期刊名称的写法)
- 硕博期刊 SCI SSCI CSSCI分不清 一文带你看懂主流期刊分类(硕博期刊SCISSCI)
- 辱华品牌新百伦官宣新代言人IU,个别粉丝希望get爱豆同款(辱华品牌新百伦官宣新代言人IU)
- 巅峰时期被爆床照,曾被选国民最讨厌女星,IU不为人知的黑历史(巅峰时期被爆床照)
- 每天1万吨牛奶倒进下水道,美国大萧条一幕重现(每天1万吨牛奶倒进下水道)
- 如何看待美国数十万加仑牛奶倒下水道 历史又重演了(如何看待美国数十万加仑牛奶倒下水道)
热门推荐
- python批量图像换背景(详解Python给照片换底色蓝底换红底)
- sql如何查找10个以上的数据(SQL中查找某几个字段完全一样的数据)
- dedecms标签解析(Dedecms网站给图片alt属性自动调用标题的方法)
- docker启动指定容器ip(Docker每次启动容器,IP及hosts指定的操作)
- opencv人脸识别效果好吗(通过opencv制作人脸识别的窗口)
- mysql数据类型图解(MySQL数据库主从技术GTID大揭秘)
- dede模板手机端显示设置(DEDE模板中如何运行php脚本和变量在需要操作数据库字段时)
- sqlserver日期型数据类型是哪个(SQL Server时间戳功能与用法详解)
- jquery中animate
- 爬虫为什么被封了(详解爬虫被封的问题)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9