1.配置缓存文件 cache manifest
MIME TYPE:text/cache-manifest文件名称:name.appcache
作用:用于配置需要缓存的文件
2.使用方法
在服务器上添加MIME TYPE在apache virtual host 中添加
- AddType text/cache-manifest .appcache
- CACHE MANIFEST
- #VERSION 1.0
- CACHE:
- index.html
- ./js/jquery.js
- ./css/style.css
- NETWORK:
- ./upload/
- FAILBACK:
- ./proxy/ proxy.html
CACHE MANIFEST:文件标识
#VERSION 1.0 :版本号,只是一行注释,但改变可以更新缓存
CACHE:表示要缓存的文件
NETWORK:表示需要连接服务器的文件
FAILBACK:表示当没有响应时的替代方案
<html>标签添加manifest属性
- <html manifest="name.appcache">
3.更新方法
1.自动更新:浏览器在第一次访问时访问应用缓存,之后只会在cache manifest文件发生变化时更新缓存(即使注释变化也会更新,#VERSION 1.0的作用),而cache manifest中的资源文件发生变化则不会触发更新。2.手动更新:以编程方法更新缓存,先调用applicationCache.update(),此操作尝试更新用户的缓存(前提是cache manifest文件有更改)。然后当applicationCache.status为UPDATEREADY状态时,调用applicationCache.swapCache()即可将原缓存换成新缓存。
代码如下:
- var appCache = window.applicationCache;
- appCache.update(); // Attempt to update the user's cache.
- ...
- if (appCache.status == window.applicationCache.UPDATEREADY) {
- appCache.swapCache(); // The fetch was successful, swap in the new cache.
- }
避免重新加载两次的麻烦,可以设置监听器,监听网页加载时updateready的事件。
代码如下:
- // Check if a new cache is available on page load.
- window.addEventListener('load', function(e) {
- window.applicationCache.addEventListener('updateready', function(e) {
- if (window.applicationCache.status == window.applicationCache.UPDATEREADY) {
- // Browser downloaded a new app cache.
- // Swap it in and reload the page to get the new hotness.
- window.applicationCache.swapCache();
- if (confirm('A new version of this site is available. Load it?')) {
- window.location.reload();
- }
- } else {
- // Manifest didn't changed. Nothing new to server.
- }
- }, false);
- }, false);
4.在线状态检测和监视
检测:navigator.onLine 属性表示当前是否在线,如果为 true,表示在线。如果为 false, 表示离线。监视:当在线/离线状态切换时,会触发online/offline事件,这两个事件触发在body元素上,并且沿着document.body,document 和 window的顺序冒泡。
5.测试
chromw 浏览器的自带测试工具,console会显示缓存的情况- Document was loaded from Application Cache with manifest http://localhost/fdipzone/test.appcache main.html:31
- Application Cache Checking event main.html:31
- Application Cache Downloading event main.html:31
- Application Cache Progress event (0 of 1) http://localhost/fdipzone/main.html main.html:31
- Application Cache Progress event (1 of 1) main.html:31
- Application Cache UpdateReady event
6.注意事项
1. 站点离线存储的容量限制是5M2. 如果manifest文件,或者内部列举的某一个文件不能正常下载,整个更新过程将视为失败,浏览器继续全部使用老的缓存
3. 引用manifest的html必须与manifest文件同源,在同一个域下
4. 在manifest中使用的相对路径,相对参照物为manifest文件
5. CACHE MANIFEST字符串应在第一行,且必不可少
6. 系统会自动缓存引用清单文件的 HTML 文件
7. manifest文件中CACHE则与NETWORK,FALLBACK的位置顺序没有关系,如果是隐式声明需要在最前面
8. FALLBACK中的资源必须和manifest文件同源
9. 当一个资源被缓存后,该浏览器直接请求这个绝对路径也会访问缓存中的资源。
10. 站点中的其他页面即使没有设置manifest属性,请求的资源如果在缓存中也从缓存中访问
11. 当manifest文件发生改变时,资源请求本身也会触发更新
原文地址:http://blog.csdn.net/fdipzone/article/details/12718945