关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » HTML5 »HTML5离线存储原理及实现

    HTML5离线存储原理及实现

    2014-10-22 00:00:00 出处:Ico_Coco
    分享

    前言

    使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本。

    HTML5引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问。 应用程序缓存为应用带来三个优势:

    离线浏览 – 用户可在应用离线时使用它们 速度 – 已缓存资源加载得更快 减少服务器负载 – 浏览器将只从服务器下载更新过或更改过的资源。

    原理和环境

    如上面提到的HTML5的离线存储是基于一个新建的.appcache文件的,通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来。之后当网络在处于离线状态下时,浏览器会通过被离线存储的数据进行页面展示。

    就像cookie一样,html5的离线存储也需要服务器环境。
    这里提供一个小工具——简易iis服务器,把它放在项目更目录下,双击运行即可模拟服务器环境。
    链接: http://pan.baidu.com/s/1jG86UV0 密码: ja9h

    解析清单

    在开始之前要先了解下manifest(即.appcache文件),上面的解析清单要怎么写。

    manifest 文件是简单的文本文件,它告知浏览器被缓存的内容(以及不缓存的内容)。

    manifest 文件可分为三个部分:

    CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存 NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存 FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)

    在线的情况下,用户代理每次访问页面,都会去读一次manifest.假如发现其改变, 则重新加载全部清单中的资源

    CACHE MANIFEST

    第一行,CACHE MANIFEST,是必需的:

    CACHE MANIFEST /theme.css /logo.gif /main.js

    上面的 manifest 文件列出了三个资源:一个 CSS 文件,一个 GIF 图像,以及一个 JavaScript 文件。当 manifest 文件加载后,浏览器会从网站的根目录下载这三个文件。然后,无论用户何时与因特网断开连接,这些资源依然是可用的。

    NETWORK

    白名单,使用通配符”*”. 则会进入白名单的open状态. 这种状态下.所有不在相关Cache区域出现的url都默认使用HTTP相关缓存头策略.

    下面的 NETWORK 小节规定文件 “login.asp” 永远不会被缓存,且离线时是不可用的:

    NETWORK: login.asp

    可以使用星号来指示所有其他资源/文件都需要因特网连接:

    NETWORK: *

    FALLBACK

    下面的 FALLBACK 小节规定假如无法建立因特网连接,则用 “offline.html” 替代 /html5/ 目录中的所有文件:

    ALLBACK: /html5/ /404.html

    注释:第一个 URI 是资源,第二个是替补。

    更新缓存

    一旦应用被缓存,它就会保持缓存直到发生下列情况:

    用户清空浏览器缓存 manifest 文件被修改 由程序来更新应用缓存

    Demo

    case/ |-- index.html | |-- demo.appcache | |-- 简易IIS服务器.exe | `-- image |-- 01.jpg `-- 02.jpg

    index.html

    <!DOCTYPE html> <html lang="en" manifest="demo.appcache"> <head> <meta charset="UTF-8"> <title>HTML5离线存储</title> </head> <body> <img src="image/01.jpg" alt=""> <img src="image/02.jpg" alt=""> </body> </html>

    demo.appcache

    CACHE MANIFEST #v01 image/01.jpg NETWORK: * FALLBACK: /

    image文件夹下存储着
    01.jpg
    01.jpg
    02.jpg
    02.jpg

    好接着执行简易IIS服务器.exe试试看吧。
    当iis开启时
    Alt text
    当iis关闭时(是关闭,暂停看不出效果)
    Alt text

    可以看见图片1成功被离线展示出来了,图片2像正常情况一样显示不出来。

    现在我想把图片2和图片1的位置换一下呢.
    Html部分置换一下

    <body> <img src="image/02.jpg" alt=""> <img src="image/01.jpg" alt=""> </body>

    这时候发现问题来了,html明明修改了为什么图片没有置换过来呢,我不是在demo.appcache文件的NETWORK写了星号吗 除了CACHE MANIFEST文件其它都采用在线模式。查资料得知:引入manifest的页面,即使没有被列入缓存清单中,仍然会被用户代理缓存。
    好吧,那我把.appcache文件更新下,于是乎把头部的版本号修改一下#v02。刷新下页面还是没反应!再刷新,有了!为什么?

    对于浏览器来说,manifest的加载是要晚于其他资源的. 这就导致check manifest的过程是滞后的.发现manifest改变.所有浏览器的实现都是紧随这做静默更新资源.以保证下次pv,应用到更新.

    通过控制台我们能够窥探一二:

    第一次刷新,应用程序缓存更新准备事件,
    Alt text 第二次刷新才会看到效果。
    Alt text

    缓存立即执行

    我们的产品已经更新了用户却要第二次进来才能够看到,这样用户体验也太差了吧,有什么方式能够解决呢?好在html5给javascript提供了相关的API。

    API篇幅太多自行查看把,这里我晒下我测试成功的code:

    /*code1,简单粗暴的*/
    applicationCache.onupdateready = function(){
    applicationCache.swapCache();
    location.reload();
    };
    /*code2,缓存公用方法*/
    // var EventUtil = {
    // addHandler: function(element, type, handler) {
    // if (element.addEventListener) {
    // element.addEventListener(type, handler, false);
    // } else if (element.attachEvent) {
    // element.attachEvent(“on” + type, handler);
    // } else {
    // element["on" + type] = handler;
    // }
    // }
    // };
    // EventUtil.addHandler(applicationCache, “updateready”, function() { //缓存更新并已下载,要在下次进入页面生效
    // applicationCache.update(); //检查缓存manifest文件是否更新,ps:页面加载默认检查一次。
    // applicationCache.swapCache(); //交换到新的缓存项中,交换了要下次进入页面才生效
    // location.reload(); //重新载入页面
    // });

    code1一般用在页面加载时直接触发,而code2的方式可后期检查更新。

    注意事项

    站点离线存储的容量限制是5M 假如manifest文件,或者内部列举的某一个文件不能正常下载,整个更新过程将视为失败,浏览器继续全部使用老的缓存 引用manifest的html必须与manifest文件同源,在同一个域下 在manifest中使用的相对路径,相对参照物为manifest文件 CACHE MANIFEST字符串应在第一行,且必不可少 系统会自动缓存引用清单文件的 HTML 文件 manifest文件中CACHE则与NETWORK,FALLBACK的位置顺序没有关系,假如是隐式声明需要在最前面 FALLBACK中的资源必须和manifest文件同源 当一个资源被缓存后,该浏览器直接请求这个绝对路径也会访问缓存中的资源。 站点中的其他页面即使没有设置manifest属性,请求的资源假如在缓存中也从缓存中访问 当manifest文件发生改变时,资源请求本身也会触发更新
    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    正版 Windows 11产品密钥怎么查找/查看?

    还有3个月,微软将停止 Windows 10 的更新

    Windows 10 终止支持后,企业为何要立即升级?

    Windows 10 将于 2025年10 月终止技术支持,建议迁移到 Windows 11

    Windows 12 发布推迟,微软正全力筹备Windows 11 25H2更新

    Linux 退出 mail的命令是什么

    Linux 提醒 No space left on device,但我的空间看起来还有不少空余呢

    hiberfil.sys文件可以删除吗?了解该文件并手把手教你删除C盘的hiberfil.sys文件

    Window 10和 Windows 11哪个好?答案是:看你自己的需求

    盗版软件成公司里的“隐形炸弹”?老板们的“法务噩梦” 有救了!

    IT头条

    公安部:我国在售汽车搭载的“智驾”系统都不具备“自动驾驶”功能

    02:03

    液冷服务器概念股走强,博汇、润泽等液冷概念股票大涨

    01:17

    亚太地区的 AI 驱动型医疗保健:2025 年及以后的下一步是什么?

    16:30

    智能手机市场风云:iPhone领跑销量榜,华为缺席引争议

    15:43

    大数据算法和“老师傅”经验叠加 智慧化收储粮食尽显“科技范”

    15:17

    技术热点

    商业智能成CIO优先关注点 技术落地方显成效(1)

    用linux安装MySQL时产生问题破解

    JAVA中关于Map的九大问题

    windows 7旗舰版无法使用远程登录如何开启telnet服务

    Android View 事件分发机制详解

    MySQL用户变量的用法

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。