HTML5 离线应用之打造零请求、无流量网站的解决方法


Posted in HTML / CSS onApril 25, 2013

前言

今天Web应用程序已经很复杂了,以现在的发展,会将越来越复杂,但他有一个致命缺点,不能脱离internet链接,因此在HTML中新增了一API,

它使用一个本地存储机制很好地解决了这个问题,为离线web应用铺平了道路。
本地缓存于浏览器缓存

复制代码
代码如下:

本地缓存是为整个web应用程序服务
浏览器缓存只对单个网页服务</p> <p>任何网页都具有网页缓存
本地缓存只缓存那些你指定缓存的页面</p> <p>网页缓存不可靠、不安全,因为我们不知道网站中到底缓存了哪些页面、哪些资源
本地缓存可以控制对哪些内容进行缓存

manifest文件

web应用程序本地缓存是通过每个页面的manifest文件来管理的,manifest是一简单文本,在该文件中以清单的形式列举了需要被缓存的不需要被缓存的文件的名字、路径。

可以为每个页面单独指定manifest也可以为整个应用程序指定,例我们为hello.htm的设置:

复制代码
代码如下:

CACHE MANIFEST
CACHE:
other.html
hellow.js
images/myphoto.jpg
NETWORK:
http://LuLinniu/NotOffline
NotOffline.asp
*
FALLBACK:
online.js locale.js
CACHE:
newhellow.html
newhellow.js

在manifest文件中,第一行必须是CACHE MANIFEST,以把文本的作用告诉浏览器,即对本地缓存中的资源文件进行具体设置。
同时真正运行离线web应用程序时,需要对服务器进行配置,让服务器支持text/cache-manifest这个mime类型。

在指定文件源文件时可以把资源文件分为三类,CACHE、NETWORK、FALLBACK

复制代码
代码如下:
</p> <p>在CACHE类别中指定需要被缓存在本地的资源文件,为某个页面指定需要本地缓存的资源文件时,不需要把这个页面本身指定在CACHE类别中,
因为如果一个页面具有manifest文件,浏览器会自动对该页面进行本地缓存</p> <p>NETWORK类别为显式指定不进行缓存的资源文件,这些文件只有建立服务器端链接才能访问,本例使用通配符*表示没有进行记录的都不缓存</p> <p>FALLBACK类别中的每行中指定两个资源文件,第一个资源文件为能够在线访问时使用的资源文件,第二个为不能在线访问时使用的本地缓存文件

浏览器与服务器交互过程

当使用离线web应用程序进行工作时,有必要了解浏览器与服务器之间的交互过程:

复制代码
代码如下:

比如一个http://LuLingniu,以index.htm为主页,该主页使用index.manifest,
在文件中缓存index.htm,hello.js,hello.jpg,首次访问时流程如下:
浏览器请求url
服务器返回index.htm首页
浏览器解析index.htm网页,请求页面上所有资源文件
服务器返回资源文件
浏览器处理manifest文件,请求manifest中需要缓存的文件,即使请求过亦会再请求
服务器返回需要缓存的文件
浏览器对本地缓存进行更新,存入资源文件,并触发一个事件通知本地缓存更新</p> <p>再次打开该URL
请求url
浏览器发现页面被缓存,于是使用本地缓存文件
解析文件
浏览器像服务器请求manifest文件
服务器返回304,通知manifest文件没有变化(若是改变将会有所不同)

applicationCache对象

该对象代表了本地缓存,可以用它来通知用户本地缓存已经被更新,也允许手动更新本地缓存。

前面当浏览器对本地缓存做了更新装入新资源文件时,会触发applicationCache对象的updateready事件,通知本地缓存已被修改,然后提示用户手动刷新页面。
swapCache

swapCache方法用来手动执行本地缓存的更新,它只能在applicationCache对象的updateReady事件触发时调用,

即当资源文件发生改变时,可使用此方法手工缓存更新。

HTML / CSS 相关文章推荐
CSS3属性使网站设计增强同时不消弱可用性
Aug 29 HTML / CSS
一款纯css3实现的竖形二级导航的实例教程
Dec 11 HTML / CSS
CSS3中引入多种自定义字体font-face
Jun 12 HTML / CSS
详解Html5 Canvas画线有毛边解决方法
Mar 01 HTML / CSS
HTML5重塑Web世界它将如何改变互联网
Dec 17 HTML / CSS
html5指南-7.geolocation结合google maps开发一个小的应用
Jan 07 HTML / CSS
几个解决兼容IE6\7\8不支持html5标签的几个方法
Jan 07 HTML / CSS
HTML5新特性之type=file文件上传功能
Feb 02 HTML / CSS
原生 JS+CSS+HTML 实现时序图的方法
Jul 31 HTML / CSS
使用placeholder属性设置input文本框的提示信息
Feb 19 HTML / CSS
background-position百分比原理详解
May 08 HTML / CSS
通过feDisplacementMap和feImage实现水波特效
Apr 24 HTML / CSS
HTML5 本地存储之如果没有数据库究竟会怎样
Apr 25 #HTML / CSS
HTML5 通信API 跨域门槛将不再高、数据推送也不再是梦
Apr 25 #HTML / CSS
基于HTML5 FileSystem API的使用介绍
Apr 24 #HTML / CSS
HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题
Apr 24 #HTML / CSS
HTML5 form标签之解放表单验证、增加文件上传、集成拖放的使用方法
Apr 24 #HTML / CSS
HTML5 Web Workers之网站也能多线程的实现
Apr 24 #HTML / CSS
HTML5组件Canvas实现图像灰度化(步骤+实例效果)
Apr 22 #HTML / CSS
You might like
数组与类使用PHP的可变变量名需要的注意的问题
2013/06/20 PHP
使用php验证复选框有效性的示例
2013/11/13 PHP
php+ajax无刷新上传图片实例代码
2015/11/17 PHP
Laravel框架使用Seeder实现自动填充数据功能
2018/06/13 PHP
PHP实现一个按钮点击上传多个图片操作示例
2020/01/23 PHP
优化JavaScript脚本的性能的几个注意事项
2006/12/22 Javascript
jQuery EasyUI API 中文文档 - Form表单
2011/10/06 Javascript
jQuery实现单击按钮遮罩弹出对话框(仿天猫的删除对话框)
2014/04/10 Javascript
jQuery学习笔记之 Ajax操作篇(一) - 数据加载
2014/06/23 Javascript
js实现从数组里随机获取元素
2015/01/12 Javascript
jQuery+html5+css3实现圆角无刷新表单带输入验证功能代码
2015/08/21 Javascript
Bootstrap 源代码分析(未完待续)
2016/08/17 Javascript
AngularJS  $on、$emit和$broadcast的使用
2016/09/05 Javascript
原生JS取代一些JQuery方法的简单实现
2016/09/20 Javascript
jQuery双向列表选择器select版
2016/11/01 Javascript
使用veloticy-ui生成文字动画效果
2018/02/08 Javascript
angularJs中ng-model-options设置数据同步的方法
2018/09/30 Javascript
JavaScript中七种流行的开源机器学习框架
2018/10/11 Javascript
Node登录权限验证token验证实现的方法示例
2020/05/25 Javascript
python2.7 mayavi 安装图文教程(推荐)
2017/06/22 Python
Python3.5内置模块之random模块用法实例分析
2019/04/26 Python
python binascii 进制转换实例
2019/06/12 Python
python图片二值化提高识别率代码实例
2019/08/24 Python
python中struct模块之字节型数据的处理方法
2019/08/27 Python
Python 如何创建一个线程池
2020/07/28 Python
python音频处理的示例详解
2020/12/23 Python
CSS3实现超慢速移动动画效果非常流畅无卡顿
2014/06/15 HTML / CSS
韩国三大免税店之一:THE GRAND 中文免税店
2016/07/21 全球购物
大四毕业生学习总结的自我评价
2013/10/31 职场文书
2014年大学生党课心得体会范文
2014/03/29 职场文书
《红军不怕远征难》教学反思
2014/04/14 职场文书
应届生面试求职信
2014/07/02 职场文书
土地转让协议书
2014/09/27 职场文书
2014大学辅导员工作总结
2014/12/02 职场文书
大学四年个人总结
2015/03/03 职场文书
JavaScript实现简单拖拽效果
2021/09/15 Javascript