Linux.中国 - 开源社区

 找回密码
 骑士注册

QQ登录

微博登录


HTML5应用程序缓存Application Cache

2015-2-4 16:13    评论: 5 收藏: 4 分享: 10    

尺寸限制

Application Cache的尺寸限制统一在5M,我这里做一个测试:

如所示,两个css文件依旧超过了5M这个时候

Document was loaded from Application Cache with manifest http://localhost/applicationcache/demo.appcache
index.html:1 Application Cache Checking event
index.html:6 GET http://localhost/applicationcache/style2.css net::ERR_FAILED
index.html:1 Application Cache NoUpdate event
index.html:11 GET http://localhost/applicationcache/2.jpg net::ERR_FAILED
index.html:12 GET http://localhost/applicationcache/3.jpg net::ERR_FAILED

如所示,style2已经不能缓存了,这个会造成什么问题呢?

比如我A频道维护了自己的Application Cache,B频道也维护了自己的,这个时候A频道如果使用达到了一个峰值,会导致B频道所有的缓存失效,所以:

建议Application Cache,存储公共资源,不要存储业务资源

一些问题

由更新机制来说,首次更新manifest时,因为页面加载已经开始 甚至已经完成,缓存更新尚未完成,浏览器仍然会使用过期的资源;浏览器是当Application Cache有更新时,该次不会使用新资源,第二次才会使用。这个时候update事件中执行window.reload事件。

window.applicationCache.addEventListener("updateready", function(){
    window.location.reload()
});

由上例可以知道,缓存的不只是显示定义的文件,比如上例中的 applicationcache/时便会默认保存index.html为映射的数据,并且包含demo.appcache文件,很多时候会遇到一次文件 更新线上老是不更新,这个时候随便在manifest配置文件中做一点修改即可更新。

比如我们将这里代码做一个改变:

<html  manifest="demo.appcache">
=>
<html  manifest="demo1.appcache">

这个时候如果不做demo.appcache的更新的话,缓存将不会更新,原因是index.html被缓存了,检测的仍然是原manifest清单

各个页面统一管理自己的manifest清单,意思是a页面配置了common.js,b页面也配置了common.js,意思是a页面更新后,b页面的manifest不更改的话,b页面依旧读取的是老版本的文件,这个有一定道理却也有一定浪费,需要公共页面做处理。 

总结

从可用性与易用性来说,Application Cache是值得使用的,但是最好是做静态资源的缓存,真正要实现离线应用还得花更多的功夫呢!

参考: http://www.w3school.com.cn/html5/html_5_app_cache.asp 

文中有何错误、不足请指出。

12
查看其它分页:

发表评论


最新评论

我也要发表评论

盛时儒理败时道 2015-2-6 22:33  新浪微博网友评论
Repost
回复
yaoer 2015-2-6 17:12
1
绿色圣光 发表于 2015-2-5 21:40 的评论:
经过实践我们任务localstorage应该存储一些非关键性ajax数据,做锦上添花的事情;
任务→认为?
多谢指正,已修改,非常感谢您的细心。
回复
绿色圣光 2015-2-5 21:40
经过实践我们任务localstorage应该存储一些非关键性ajax数据,做锦上添花的事情;
任务→认为?
回复
杨晨辉_iscoiel 2015-2-5 21:03  新浪微博网友评论
技术总是在进步,简单可持续才是竞争力。
回复
-_-___-__- 2015-2-5 14:33  新浪微博网友评论
@今朝有酒TRL [喵喵]
回复
返回顶部

分享到微信朋友圈

打开微信,点击底部的“发现”,
使用“扫一扫”将网页分享至朋友圈。