百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>html5教程> h5离线缓存有哪些?h5 manifest离线缓存的利用(附代码)
分享文章到:

h5离线缓存有哪些?h5 manifest离线缓存的利用(附代码)

发布时间:09/01 来源:未知 浏览: 关键词:
什么是manifest?manifest是一个后缀名为minifest的文件,在文件中定义那些需要缓存的文件,支撑manifest的阅读器,会将依照manifest文件的规则,像文件留存在当地,从而在没有网络链接的状况下,也能拜访页面。

离线拜访对基于网络的利用而言越来越重要。虽然所有阅读器都有缓存机制,但它们并不成靠,也不必然总能起到预测的作用。HTML5 使用 ApplicationCache 接口解决了由离线带来的部分难题。

使用缓存接口可为您的利用带来以下三个优势:

  1. 离线阅读 - 会员可在离线时阅读您的完全网站

  2. 速度 - 缓存资源为当地资源,因此加载速度较快。

  3. 效劳器负载更少 - 阅读器只会从发生了更换的效劳器下载资源。

利用缓存(又称 AppCache)可让开发人员指定阅读器应缓存哪些文件以供离线会员拜访。即便会员在离线状态下按了刷新按钮,您的利用也会正常加载和运转。

援用清单文件

要启用某个利用的利用缓存,请在文档的 html 标志中增加 manifest 属性:
manifest 属性可指向绝对网址或相对途径,但绝对网址必需与响应的网络利用同源。清单文件可使用任何文件扩展名,但必需以准确的 MIME 类型供给(拜见下文)。

<html manifest="/cache.manifest">
  ...
</html>

或

<html manifest="http://www.example.com/example.mf">
  ...
</html>

您应在要缓存的网络利用的每个页面上都增加 manifest 属性。假如网页不包括 manifest 属性,阅读器就不会缓存该网页(除非清单文件中明白列出了该属性)。
这就意味着会员阅读的每个包括 manifest 的网页都会隐式增加到利用缓存。因此,您无需在清单中列出每个网页。

清单文件必需以 text/cache-manifest MIME类型供给。文件后缀名可以自定义(倡议为.manifest)所以我们需要此刻效劳端将.manifest后缀的文件类型声明为text/cache-manifest。
以apache为例,我们需要在httpd.conf中加上:AddType text/cache-manifest .manifest

清单文件构造

简便的清单格局如下:

CACHE MANIFEST
index.html
stylesheet.css
images/logo.png
scripts/main.js

该示例将在指定此清单文件的网页上缓存四个文件。

您需要留意以下几点:

CACHE MANIFEST 字符串应在第一行,且必不成少。

网站的缓存数据量不得超越 5 MB。不外,假如您要编写的是针对 Chrome 网上利用店的利用,可使用 unlimitedStorage 取消该限制。

假如清单文件或其中指定的资源没法下载,就没法停止整个缓存更新进程。在这种状况下,阅读器将连续使用原利用缓存。

我们再来看看更复杂的示例:

CACHE MANIFEST
# 2010-06-18:v2

# Explicitly cached 'master entries'.
CACHE:
/favicon.ico
index.html
stylesheet.css
images/logo.png
scripts/main.js

# Resources that require the user to be online.
NETWORK:
login.php
/myapi
http://api.twitter.com

# static.html will be served if main.py is inaccessible
# offline.jpg will be served in place of all images in images/large/
# offline.html will be served in place of all other .html files
FALLBACK:
/main.py /static.html
images/large/ images/offline.jpg
*.html /offline.html

以“#”开头的行是注释行,但也可用于其他用处。例如更新缓存
利用缓存只在其清单文件发生更换时才会更新。例如,假如您修改了图片资源或更换了 JavaScript 函数,这些更换不会从新缓存。您必需修改清单文件本身才能让阅读器刷新缓存文件。使用生成的版本号、文件哈希值或时间戳创立注释行,可确保会员获得您的软件的最新版。
您还可以在显现新版本后,以编程方式更新缓存,如更新缓存部分中所述。

假如页面引入了缓存清单文件,那么清单文件必需包括当前页面需要的所有文件(css,js,image...),不然不会被加载,所以除去牢固需要缓存的文件,倡议在文件中的NETWORK一项加上星号*,表示其余所有文件

清单可包罗以下三个不一样部分:CACHE、NETWORK 和 FALLBACK。

CACHE:

这是条目的默许部分。系统会在首次下载此标头以下出的文件(或紧跟在 CACHE MANIFEST 后的文件)后显式缓存这些文件。

NETWORK:

此部分以下出的文件是需要连接到效劳器的白名单资源。不管会员可否处于离线状态,对这些资源的所有恳求都会绕过缓存。可使用通配符。

FALLBACK:

此部分是可选的,用于指定没法拜访资源时的后备网页。其中第一个 URI 代表资源,第二个代表后备网页。两个 URI 必需相关,并且必需与清单文件同源。可使用通配符。
请留意:这些部分可按任意次序摆列,且每个部分均可在统一清单中反复显现。

以下清单定义了会员尝试离线拜访网站的根时显示的“综合性”网页 (offline.html),也表白了其他所有资源(例如长途网站上的资源)均需要互联网连接。

CACHE MANIFEST
# 2010-06-18:v3

# Explicitly cached entries
index.html
css/style.css

# offline.html will be displayed if the user is offline
FALLBACK:
/ /offline.html

# All other resources (e.g. sites) require the user to be online.
NETWORK:
*

# Additional resources to cache
CACHE:
images/logo1.png
images/logo2.png
images/logo3.png

请留意:系统会主动缓存援用清单文件的 HTML 文件。因此您无需将其增加到清单中,但我们倡议您这样做。

请留意:HTTP 缓存标头乃至对通过 SSL 供给的网页设定的缓存限制将被更换为缓存清单。因此,通过 https 供给的网页可实现离线运转。

更新缓存

利用在离线后将保持缓存状态,除非发生以下某种状况:

  1. 会员清除了阅读器对您网站的数据储备。

  2. 清单文件经过修改。请留意:更新清单中列出的某个文件并不料味着阅读器会从新缓存该资源。清单文件本身必需停止更换。

  3. 利用缓存通过编程方式停止更新。

相关文章引荐:

HTML5离线缓存Manifest是啥_html5教程技巧

H5利用缓存-Manifest的详细介绍

以上就是h5离线缓存是啥?h5 manifest离线缓存的利用(附代码)的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板