HTML5-应用程序缓存(Application Cache)

一、什么是应用程序缓存?

  HTML5 引入了应用程序缓存(Application Cache),这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问。

二、优势

  离线浏览 - 用户可在应用离线时使用它们

  速度 - 已缓存资源加载得更快

  减少服务器负载 - 浏览器将只从服务器下载更新过或更改过的资源。

三、原理

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

四、如何使用?

  在文档的 标签中包含 manifest 属性。

  在manifest文件编写离线存储的资源。

  在离线状态时,操作window.applicationCache进行需求实现。

1.在文档的<html> 标签中包含 manifest 属性。

demo.html:

<!DOCTYPE html>
<html lang="en" manifest="demo.appcache">
<head>
    <meta charset="UTF-8">
    <title>demo</title>
</head>
<body>
    <img src="img.jpg" height="500" width="900" alt="">
    其它内容...
</body>
</html>

2.在manifest文件编写离线存储的资源。

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

manifest 文件可分为三个部分:

  CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存

  NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存,可以使用星号来指示除CACHE MANIFEST外的所有其他资源/文件都需要因特网连接。

  FALLBACK - 在此标题下列出的文件规定当页面无法访问时的替代页面(比如 404 页面)。

 demo.appcache:

CACHE MANIFEST
#version 1.0
CACHE:
    img.jpg
NETWORK:
    *
FALLBACK:
    /demo/ /404.html

代码意为:

  demo.html中的img在首次下载后进行缓存;其他文件内容都需要因特网连接;如果无法建立因特网连接,则用 "404.html" 替代 /demo/ 目录中的所有文件。

注意:

  如果编辑了一幅图片,或者修改了一个 JavaScript 函数,这些改变都不会使缓存更新,manifest 文件更改时缓存会更新。以 "#" 开头的是注释行,更新注释行中的日期和版本号是一种使浏览器重新缓存文件的办法。

  manifest 文件需要配置正确的 MIME-type,即 "text/cache-manifest"。必须在 web 服务器上进行配置。

在tomcat服务器中的conf/web.xml中添加:

<mime-mapping>
    <extension>manifest</extension>
    <mime-type>text/cache-manifest</mime-type>
</mime-mapping>

  在开发者工具的Network面板下,可以看到img.jpg的Size为(from disk cache),意味着是从缓存中读取的。

image.png

3.在离线状态时,操作window.applicationCache进行需求实现。

五、更新缓存

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

  用户清空浏览器缓存

  manifest 文件被修改

  由程序来更新应用缓存

六、注意事项

  浏览器对缓存数据的容量限制可能不太一样(某些浏览器设置的限制是每个站点 5MB)。

  如果manifest文件,或者内部列举的某一个文件不能正常下载,整个更新过程都将失败,浏览器继续全部使用老的缓存。

  引用manifest的html必须与manifest文件同源,在同一个域下。FALLBACK中的资源必须和manifest文件同源。

  当manifest文件发生改变时,会触发更新请求资源。系统会自动缓存引用清单文件的 HTML 文件。

原文地址:https://www.cnblogs.com/superlizhao/p/8780310.html