html5 manifest 离线缓存

作者: 高高3575 | 来源:发表于2017-04-06 10:51 被阅读0次

    **干什么用的?
    **
    离线缓存为的是第一次请求后,根据manifest文件进行本地缓存,并且在下一次请求后进行展示(若有缓存的话,无需再次进行请求而是直接调用缓存),最根本的感觉是它使得WEB从online可以延伸到了offline领域。

    应用场景
    h5游戏及一些页面内容不经常会变动,相对较为固定的内容。

    怎么用的?
    若想使用manifest功能,需要在需要进行缓存功能的html文件之中写入 声明

    <meta manifest = ‘demo.appcache’> // 这个文件格式是官方推荐的
    

    这里,若遇到如此报错

     Application Cache Error event: Manifest fetch failed (404)
    

    其原因是因为 manifest文件需要正确的配置MIME-type(描述该消息的媒体类型),即
    “text/cache-manifest”,必须在服务器端进行配置。

    manifest文件如何进行配置?

    首先manifest分为三个部分

    1、CACHE MANIFEST //指出需要进行manifest的文件,此文件将会在首次下载后被缓存下来

    CACHE MANIFESTCACHE:/index.css/index.html/index.js
    

    2、NETWORK //指出需要向服务器请求即不需要manifest的文件,此文件不会被缓存,若为*则表示所有文件均需要进行网络请求,而不使用缓存。

    NETWORK:*
    

    3、FALLBACK //指出当页面无法进行访问时,显示的页面(替换的页面),例子中,当html5文件夹中的文件出现异常情况,,使用404.html页面替换掉异常页面 (第一个uri路径是资源地址,第二个是备胎地址)

    FALLBACK:/html5/ /404.html
    

    完整的实例

    CACHE MANIFEST# 2017-04-06 v1.0.0
    CACHE:/theme.css/logo.gif/main.js
    NETWORK:login.asp
    FALLBACK:/html5/ /404.html
    

    注意:这里的版本号,是我们人为规定的,而非是manifest自带的属性,当每一次html加载到manifest时,会对manifest配置文件进行脏检查,当检测到manifest文件被修改后,之前的缓存将会被弃用,转而去根据manifest文件中配置的新内容进行缓存。

    查看:

    670E294B-9EB2-48F9-9C1B-4885FD7AD37E.png

    被缓存的文件可以使用谷歌浏览器进行查看: f12 -> Application -> Application Cache

    ftchinese 手机版使用了离线缓存技术,可以去看下其源码以及缓存的文件是如何进行存储的

    问题!

    manifest除了缓存manifest.appcache文件所指定的资源外,还必定会缓存当前的html页面,即

    <meta manifest=‘demo.appcache'>
    

    标签所在的页面以及demo.appcache文件里面所规定的静态资源一并存入 application Cache 之中。
    当用户再一次访问该页面时,demo.appcache文件之中CACHE MANIFEST所指向的资源就不需要重新进行加载了,但是问题是,当前的html页面也会跟着cache直接读出来了,可能会造成即使 我们的页面更新了,但是用户还是看的老旧版本页面(因为更新mainfest的时候,页面加载已经开始了,但是缓存更新却尚未完成,浏览器还是会使用缓存的资源,当浏览器检测到了Application Cache有更新时,本次不会使用新的资源,下一次才会进行使用)

    解决方案:

    applicationCache.addEventListener("updateready",function(){
    applicationCache.swapCache();      // 手工更新本地缓存
    location.reload();    //重新加载页面页面
    },true);````
    
    添加事件监听,当监听到本地缓存更新后,进行重载页面,以达到更新的目的。
    
    ****
    
    **写在最后:**
    
    **这是本人第一篇简书,文笔难免稚嫩,希望各位前辈能够不吝批评与建议,祝各位工作顺利。**
    
    
    
    
    

    相关文章

      网友评论

        本文标题:html5 manifest 离线缓存

        本文链接:https://www.haomeiwen.com/subject/ppvmottx.html