您的位置:首页 > Web前端 > 其它 > 正文

HTML5离线缓存

更多 时间:2016-4-2 类别:Web前端 浏览量:1350

HTML5离线缓存

HTML5离线缓存

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

 

一、HTML5离线缓存优点

1、离线浏览 – 用户可在应用离线时使用它们

2、速度 – 已缓存资源加载得更快

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

 

二、HTML5离线缓存基本流程

第一次正确配置app cache后,当我们再次访问该应用时,浏览器会首先检查manifest文件是否有变动,如果有变动就会把相应的变得跟新下来,同时改变浏览器里面的app cache,如果没有变动,就会直接把app cache的资源返回。

 

三、离线缓存与传统浏览器缓存区别

 

1、离线缓存是针对整个应用,浏览器缓存是单个文件

2、离线缓存断网了还是可以打开页面,浏览器缓存不行

3、离线缓存可以主动通知浏览器更新资源

 

四、manifest文件的写法

  •  
  • 
    CACHE MANIFEST
    #上面一句必须
    #v1.0.0
    #需要缓存的文件
    CACHE:
    a.js
    b.css
    #不需要缓存的文件
    NETWORK:
    *
    #无法访问页面
    FALLBACK:
    404.html
    
    		
  •  

    五、manifest文件的格式说明

     

    1、CACHE MANIFEST(必须)

    (1)、为固定格式,必须写在最前面

    (2)、以#号开头的是注释,一般会在第二行写个版本号,用来在缓存的文件更新时,更改manifest的作用,可以是版本号,时间戳或者md5码等等。

     

    2、CACHE(必须)

    (1)、标识出哪些文件需要缓存,可以是相对路径也可以是绝对路径。

    (2)、当 manifest 文件加载后,浏览器会从网站的根目录下载这些文件。然后,无论用户何时与因特网断开连接,这些资源依然是可用的。

     

    3、NETWORK(可选)

    (1)、这一部分是要绕过缓存直接读取的文件,需要与服务器连接,且不会被缓存 

    (2)、使用通配符”*”,表示所有其他资源/文件都需要因特网连接

     

    4、NETWORK(可选)

    (1)、指定了一个后备页面,当资源无法访问时,浏览器会使用该页面。该段落的每条记录都列出两个 URI—第一个表示资源,第二个表示后备页面。两个 URI 都必须使用相对路径并且与清单文件同源。

    (2)、例如

    如果无法建立因特网连接,则用 “404.html” 替代 /html5/ 目录中的所有文件

    FALLBACK:/html5/ /404.html

    如果无法建立因特网连接,则用 “404.html” 替代所有文件

    FALLBACK:*.html /404.html

     

     

    六、如何更新HTML5离线缓存

     

    如下三种方式,可以更新缓存:


    1、更新manifest文件

    (1)、给manifest添加、修改或删除,都可更新缓存 。

    (1)、如果我们更改了js,而没有新增或删除,前面例子中注释中的版本号,可以很好的用来更新manifest文件。


    2、通过javascript操作

    html5中引入了js操作离线缓存的方法,下面的js可以手动更新本地缓存。

    window.applicationCache.update();


    3、清除浏览器缓存

    如果用户清除了浏览器缓存(手动或用其他一些工具)都会重新下载文件

     

    七、对Manifest 文件常用的事件

     

    1、核心是applicationCache对象,有个status属性,表示应用缓存的当前状态:

    0(UNCACHED) :  无缓存, 即没有与页面相关的应用缓存

    1(IDLE) : 闲置,即应用缓存未得到更新

    2 (CHECKING) : 检查中,即正在下载描述文件并检查更新

    3 (DOWNLOADING) : 下载中,即应用缓存正在下载描述文件中指定的资源

    4 (UPDATEREADY) : 更新完成,所有资源都已下载完毕

    5 (IDLE) :  废弃,即应用缓存的描述文件已经不存在了,因此页面无法再访问应用缓存

     

    2、 相关的事件

    表示应用缓存状态的改变:

    checking : 在浏览器为应用缓存查找更新时触发

    error : 在检查更新或下载资源期间发送错误时触发

    noupdate : 在检查描述文件发现文件无变化时触发

    downloading : 在开始下载应用缓存资源时触发

    progress:在文件下载应用缓存的过程中持续不断地下载地触发

    updateready : 在页面新的应用缓存下载完毕触发

    cached : 在应用缓存完整可用时触发

     

     

    八、HTML5离线缓存使用注意事项

     

    (1)、manifest文件的mime-type必须是 text/cache-manifest类型

    (2)、站点离线存储的容量限制是5M

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

    (4)、引用manifest的html必须与manifest文件同源,在同一个域下

    (5)、在manifest中使用的相对路径,相对参照物为manifest文件

    (6)、CACHE MANIFEST字符串应在第一行,且必不可少

    (7)、系统会自动缓存引用清单文件的 HTML 文件

    (8)、manifest文件中CACHE则与NETWORK,FALLBACK的位置顺序没有关系,如果是隐式声明需要在最前面

    (9)、FALLBACK中的资源必须和manifest文件同源

    (10)、当一个资源被缓存后,该浏览器直接请求这个绝对路径也会访问缓存中的资源。

    (11)、站点中的其他页面即使没有设置manifest属性,请求的资源如果在缓存中也从缓存中访问

    (12)、当manifest文件发生改变时,资源请求本身也会触发更新

     

    标签:HTML5