什么是应用程序缓存(Application Cache)?
HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问。
应用程序缓存为应用带来三个优势:
离线浏览 - 用户可在应用离线时使用它们
速度 - 已缓存资源加载得更快
减少服务器负载 - 浏览器将只从服务器下载更新过或更改过的资源。
浏览器支持
所有主流浏览器均支持应用程序缓存,除了 Internet Explorer。
Cache Manifest 基础
如需启用应用程序缓存,请在文档的 <html> 标签中包含 manifest 属性:
每个指定了 manifest 的页面在用户对其访问时都会被缓存。如果未指定 manifest 属性,则页面不会被缓存(除非在 manifest 文件中直接指定了该页面)。
manifest 文件的建议的文件扩展名是:".appcache"。
请注意,manifest 文件需要配置正确的 MIME-type,即 "text/cache-manifest"。必须在 web 服务器上进行配置。
Manifest 文件
manifest 文件是简单的文本文件,它告知浏览器被缓存的内容(以及不缓存的内容)。
manifest 文件可分为三个部分:
CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存
NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存
FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)
上述资料copy自http://www.w3school.com.cn/html5/html_5_app_cache.asp
下面贴一下我自己操作的流程:
1、web容器配置。Application Cache的核心是manifest 文件,要加载manifest 文件,就要先让web容易认识这个东东,所以要先配置MIME-type 映射。我用的是tomcat容器,找到conf/web.xml文件,在那一大堆<mime-mapping>后面加上manifest配置
,保存重启,完成第一步。
2、编写manifest文件。我的manifest文件为cache/demo.appcache,内容入下:
3、html使用manifest文件。
baidu_sylogo1.gif为缓存,而cat.gif是直接从服务器读取。
4、测试。笔者用chrome测试了一下正常显示,firefox也OK。不过PC上看不出啥来(比较明显的是manifest 文件中的路径配置错误,debug模式会报错,正常的情况下浏览器会提示是否使用xxx网站提供的静态数据),我用我自己的手机测试了一下,效果比较明显(WI-FI坏境下)。刷新页面的速度很快,关闭WI-FI时,重新刷页面,可以看到第一个图片,而第二个图片显示不出来。
HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问。
应用程序缓存为应用带来三个优势:
离线浏览 - 用户可在应用离线时使用它们
速度 - 已缓存资源加载得更快
减少服务器负载 - 浏览器将只从服务器下载更新过或更改过的资源。
浏览器支持
所有主流浏览器均支持应用程序缓存,除了 Internet Explorer。
Cache Manifest 基础
如需启用应用程序缓存,请在文档的 <html> 标签中包含 manifest 属性:
- <!DOCTYPE HTML>
- <html manifest="demo.appcache">
- ...
- </html>
每个指定了 manifest 的页面在用户对其访问时都会被缓存。如果未指定 manifest 属性,则页面不会被缓存(除非在 manifest 文件中直接指定了该页面)。
manifest 文件的建议的文件扩展名是:".appcache"。
请注意,manifest 文件需要配置正确的 MIME-type,即 "text/cache-manifest"。必须在 web 服务器上进行配置。
Manifest 文件
manifest 文件是简单的文本文件,它告知浏览器被缓存的内容(以及不缓存的内容)。
manifest 文件可分为三个部分:
CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存
NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存
FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)
上述资料copy自http://www.w3school.com.cn/html5/html_5_app_cache.asp
下面贴一下我自己操作的流程:
1、web容器配置。Application Cache的核心是manifest 文件,要加载manifest 文件,就要先让web容易认识这个东东,所以要先配置MIME-type 映射。我用的是tomcat容器,找到conf/web.xml文件,在那一大堆<mime-mapping>后面加上manifest配置
- <!--html5 mime-type setting -->
- <mime-mapping>
- <extension>manifest</extension>
- <mime-type>text/cache-manifest</mime-type>
- </mime-mapping>
- <!--html5 mime-type setting -->
2、编写manifest文件。我的manifest文件为cache/demo.appcache,内容入下:
- CACHE MANIFEST
- # 2012-11-01 v1.0.0
- ../image/baidu_sylogo1.gif
- NETWORK:
- ../image/cat.gif
- FALLBACK:
- 404.html
3、html使用manifest文件。
- <!DOCTYPE>
- <html manifest="../cache/demo.appcache">
- <head>
- <title>test4.html</title>
- <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
- <meta http-equiv="description" content="this is my page">
- <meta http-equiv="content-type" content="text/html; charset=UTF-8">
- </head>
- <body>
- <div>
- <img alt="aaa" src="../image/baidu_sylogo1.gif" >
- <img id="msg" alt="bbb" src="" >
- <script type="text/javascript">
- var msg=document.getElementById("msg");
- msg.src='../image/cat.gif';
- </script>
- </div>
- </body>
- </html>
baidu_sylogo1.gif为缓存,而cat.gif是直接从服务器读取。
4、测试。笔者用chrome测试了一下正常显示,firefox也OK。不过PC上看不出啥来(比较明显的是manifest 文件中的路径配置错误,debug模式会报错,正常的情况下浏览器会提示是否使用xxx网站提供的静态数据),我用我自己的手机测试了一下,效果比较明显(WI-FI坏境下)。刷新页面的速度很快,关闭WI-FI时,重新刷页面,可以看到第一个图片,而第二个图片显示不出来。
相关推荐
WEB开发 之 HTML 5 应用程序缓存.docx
HTML5 应用程序缓存 使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本。 什么是应用程序缓存(Application Cache)? HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并...
!!!!!服务器需要添加配置!!!!!!!!! 建议使用Google Chrome 测试 我的是Apache服务器 conf/httpd.conf 文件的mime_module 中添加 . . . AddType text/cache-manifest .appcache </IfModule>
在HTML5之前,我们需要接入网络才能访问,这毫无疑问是网站多次请求服务器,造成速度变慢,对于PC用户,网络相对比较稳定,载入速度也不会差太多。但是移动端呢?移动端依赖无线信号、依赖信号塔、位置不固定、受...
正如 manifest 英译的名字:离线应用程序缓存,这项功能是设计给会有离线场景的应用来使用,例如:需要离线使用的手机APP/H5,亦或是PC端的纯静态页面。 三、问题 1.服务器资源更新后显示滞后需要多刷新一次页面 ...
html+app、mui+app等html移动端开发、计算当前APP缓存的数据大小和清除当前APP缓存等常用函数,为了解决html移动端开发因图片缓存或数据缓存到最后内存过大后导致app程序卡顿。
本地存储-应用-缓存 HTML5 本地存储和应用程序缓存演示 对于应用程序缓存功能,演示文件必须托管在服务器上。 本地存储将直接从文件系统工作。
该插件生成清单文件,用于HTML应用程序缓存。 包括所有已发布的页面和文章,以及索引页面。 其他资源可以在APPCACHE_RESOURCES设置中手动指定。 设定值 APPCACHE_MANIGEST_NAME :清单文件的名称,默认为'manifest....
7.4 创建HTML5 WebSockets应用程序 158 7.4.1 编写HTML文件 159 7.4.2 添加WebSocket代码 160 7.4.3 添加Geolocation代码 160 7.4.4 合并所有内容 161 7.4.5 终代码 163 7.5 小结 165 第8章 Forms API 166 ...
ASP.NET 2.0动态网站开发基础教程(C#) 第10章 配置ASP.NET应用程序 Global.asax Web config 缓存技术(共12页).ppt ASP.NET 2.0动态网站开发基础教程(C#) 第11章 提高ASP.NET应用程序的安全性 身份验证和授权 ...
HTML5引入了应用程序缓存技术,意味着web应用可进行缓存,并在没有网络的情况下使用,通过创建cache manifest文件,可以轻松的创建离线应用。 Application Cache带来的三个优势是: ① 离线浏览 ② 提升页面载入速度...
解释应用程序缓存、触摸事件和数据存储 详细介绍如何创建像本机应用程序一样运行的混合应用程序,讲解如何最大限度地利用JSON 、REST、 Qauth、 jQuery、 AJAX等技术 分享了有关Apple App Store和Android ...
这个 Cordova / PhoneGap (3.5+) 插件通过利用原生音频 API 在基于音频的应用程序中实现并发(多声道播放)、复音(多语音播放)和最小化延迟(通过缓存)。设计用于基于 HTML5 的跨平台游戏和移动/混合音频应用程序...
Webpack的应用程序缓存插件 用法 var AppCachePlugin = require ( 'appcache-webpack-plugin' ) ; module . exports = { plugins : [ new AppCachePlugin ( { cache : [ 'someOtherAsset.jpg' ] , network : ...
用于简单中间件,允许使用 HTML5 应用程序缓存。 用法 通过 NPM 安装: $ npm install connect-app-cache 在您的代码中使用它: $ var appCache = require('connect-app-cache'); 包含到连接应用程序中: $ ...
HTML5引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在离线时进行访问。 :pushpin:应用程序缓存为应用带来三个优势: 离线浏览 – 用户可在应用离线时使用它们 速度 – 已缓存资源加载得更快 减少服务器...