html5游戏缓存,HTML5 实现离线数据缓存

1.配置缓存文件 cache manifestMIME TYPE:text/cache-manifest

文件名称:name.appcache

作用:用于配置需要缓存的文件

2.使用方法在服务器上添加MIME TYPE在apache virtual host 中添加

AddType text/cache-manifest .appcache创建 name.manifest,文件后缀可自定义,定义后需要在服务器上添加对应的MIME TYPE

CACHE MANIFEST

#VERSION 1.0

CACHE:

index.html

./js/jquery.js

./css/style.css

NETWORK:

./upload/

FAILBACK:

./proxy/ proxy.html

CACHE MANIFEST:文件标识#VERSION 1.0 :版本号,只是一行注释,但改变可以更新缓存CACHE:表示要缓存的文件NETWORK:表示需要连接服务器的文件FAILBACK:表示当没有响应时的替代方案标签添加manifest属性

3.更新方法1.自动更新:浏览器在第一次访问时访问应用缓存,之后只会在cache manifest文件发生变化时更新缓存(即使注释变化也会更新,#VERSION 1.0的作用),而cache manifest中的资源文件发生变化则不会触发更新。

2.手动更新:以编程方法更新缓存,先调用applicationCache.update(),此操作尝试更新用户的缓存(前提是cache manifest文件有更改)。然后当applicationCache.status为UPDATEREADY状态时,调用applicationCache.swapCache()即可将原缓存换成新缓存。

代码如下:

varappCache = window.applicationCache;

appCache.update(); // Attempt to update the user's cache.

...

if(appCache.status == window.applicationCache.UPDATEREADY) {

appCache.swapCache(); // The fetch was successful, swap in the new cache.

}使用update() 和 swapCache() 不会向用户提供更新的资源,只会让浏览器检查是否有新的cache manifest清单,下载指定的更新内容及重新填充应用缓存。因此需要两次加载才能向用户提供新内容。第一次是获得新的应用缓存,第二次是刷新网页内容。

避免重新加载两次的麻烦,可以设置监听器,监听网页加载时updateready的事件。

代码如下:

// Check if a new cache is available on page load.

window.addEventListener('load',function(e) {

window.applicationCache.addEventListener('updateready',function(e) {

if(window.applicationCache.status == window.applicationCache.UPDATEREADY) {

// Browser downloaded a new app cache.

// Swap it in and reload the page to get the new hotness.

window.applicationCache.swapCache();

if(confirm('A new version of this site is available. Load it?')) {

window.location.reload();

}

} else{

// Manifest didn't changed. Nothing new to server.

}

}, false);

}, false);

4.在线状态检测和监视检测:navigator.onLine 属性表示当前是否在线,如果为 true,表示在线。如果为 false, 表示离线。

监视:当在线/离线状态切换时,会触发online/offline事件,这两个事件触发在body元素上,并且沿着document.body,document 和 window的顺序冒泡。

5.测试chromw 浏览器的自带测试工具,console会显示缓存的情况

Document was loaded from Application Cache with manifest http://localhost/fdipzone/test.appcache main.html:31

Application Cache Checking event main.html:31

Application Cache Downloading event main.html:31

Application Cache Progress event (0 of 1) http://localhost/fdipzone/main.html main.html:31

Application Cache Progress event (1 of 1)  main.html:31

Application Cache UpdateReady event

6.注意事项1. 站点离线存储的容量限制是5M2. 如果manifest文件,或者内部列举的某一个文件不能正常下载,整个更新过程将视为失败,浏览器继续全部使用老的缓存

3. 引用manifest的html必须与manifest文件同源,在同一个域下

4. 在manifest中使用的相对路径,相对参照物为manifest文件

5. CACHE MANIFEST字符串应在第一行,且必不可少

6. 系统会自动缓存引用清单文件的 HTML 文件

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

8. FALLBACK中的资源必须和manifest文件同源

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

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

11. 当manifest文件发生改变时,资源请求本身也会触发更新

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值