测试环境和工具   chromium  18.0.1025.151 (开发编译版 130497 Linux) Ubuntu 11.04

一、测试内容

1.A页面manifest缓存的js文件,B页面不设manifest是否能使用缓存的js文件

2.A页面和B页面分别使用两个不同的manifest文件,但都缓存了同一个js文件,两页面更新缓存时,是否会相互影响?

3.两个页面使用同一个manifest文件,是否是共用一份缓存?

二、详细测试

     1、A页面manifest缓存的js文件,B页面不设manifest是否能使用缓存的js文件 ?

先上文件

cache.html

  1. <html manifest="m.manifest">
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
  4. <script type="text/javascript" src="m.js"></script>
  5. </head>
  6. <body>
  7. ver:1<p>
  8. <input type="button" value="shwo_ver" onclick="show_ver();" /><p>
  9. <input type="button" value="load_js" onclick="load_js();" /><p>
  10. <input type="button" value="is_online" onclick="is_online();" /><p>
  11. </body>
  12. </html>

un_cache.html

  1. <html>
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
  4. <script type="text/javascript" src="m.js"></script>
  5. </head>
  6. <body>
  7. ver:1<p>
  8. <input type="button" value="shwo_ver" onclick="show_ver();" /><p>
  9. <input type="button" value="load_js" onclick="load_js();" /><p>
  10. <input type="button" value="is_online" onclick="is_online();" /><p>
  11. </body>
  12. </html>

m.manifest

  1. CACHE MANIFEST
  2. # VERSION
  3. # 直接缓存的文件dd
  4. CACHE:
  5. m.js
  6. m1.js
  7. # 需要在时间在线的文件
  8. NETWORK:
  9. # 替代方案
  10. FALLBACK:

m.js

  1. var ver = "1";
  2. function show_ver() {
  3. alert(ver);
  4. }
  5. function load_js() {
  6. javascript:void((function(){var e=document.createElement('script');e.setAttribute('src','m1.js');document.body.appendChild(e);})())
  7. }
  8. function is_online() {
  9. alert(navigator.onLine);
  10. }

测试方法:

分别访问cache.html和un_cache.html, 查看js版本都是为“1”.

然后修改m.js的版本为“2”.

刷新两个页面再次查看,cache.html显示为“1”, 而un_cache.html显示为“2”

测试结论:manifest建立的缓存文件,不会被没有manifest的页面读取。

2.A页面和B页面分别使用两个不同的manifest文件,但都缓存了同一个js文件,两页面更新缓存时,是否会相互影响?

新增两个文件

cache1.html

  1. <html manifest="m1.manifest">
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
  4. <script type="text/javascript" src="m.js"></script>
  5. </head>
  6. <body>
  7. ver:1<p>
  8. <input type="button" value="shwo_ver" onclick="show_ver();" /><p>
  9. <input type="button" value="load_js" onclick="load_js();" /><p>
  10. <input type="button" value="is_online" onclick="is_online();" /><p>
  11. </body>
  12. </html>

m1.manifest

  1. CACHE MANIFEST
  2. # VERSION
  3. # 直接缓存的文件dd
  4. CACHE:
  5. m.js
  6. m1.js
  7. # 需要在时间在线的文件
  8. NETWORK:
  9. # 替代方案
  10. FALLBACK:

测试方法:

改动一下两个manifest文件,访问cache.html和cache1.html,确保都建立新缓存,并且显示js版本号一致;

修改m.js的版本号,并改动一下m.manifest文件;

刷新cache.html和cache1.html,并再次查看js版本号,发现cache.html的版本号变了,但cache1.html的版本号没有变化。

测试结论:不同manifest文件的缓存,不会相互之间有影响

3.两个页面使用同一个manifest文件,是否是共用一份缓存?

新增cache2.html代码完全同cache.html.

测试方法:

访问cache.html和cache2.html,并确保都是显示最新js版本“4”;

修改js版本为“5”,并改动没m.manifest文件;

刷新cache.html,显示js版本为“5”;

修改js版本为“6”, 然后刷新cache2.html,显示js版本为“5”,而不是“6”.

测试结论:同一manifest文件的缓存只有一份,被多个页面使用时也是如此

三、总结

通过以上测试,我们有理由可以这么认为:一个manifest文件会创建一份缓存,不同的manifest文件其缓存的内容是互不干扰的。这些特性应该有相关文档说明的,但可惜我没有找到有,若大家找到有,请分享给我一下。

一、测试内容

1.manifest文件改动后,浏览器在什么时候更新缓存?

2.一个新页面使用已有的manifest文件(其他页面使用的,并且已经创建好缓存),初次访问时,会引起整个缓存更新吗?

二、详细测试

 1.manifest文件改动后,浏览器在什么时候更新缓存?

使用测试(一)的cache.html, m.js, m.manifest三个文件。js版本号1。

测试过程:

访问cache.html,确保缓存数据是最新的;

修改m.js让版本号为“2”,并修改m.manifest文件(改动一下注释即可);

刷新cache.html, 查看js版本是“1”,但chrom的console提示更新缓存了;

修改m.js让版本号为“3”,再次刷新cache.html, 查看js的版本号是“2”,chrom的console没有提示有缓存更新;

修改m.js让版本号为“4”,再次刷新cache.html, 查看js的版本号是“2”.

测试结论:浏览器检测到manifest文件有变化时,会更新缓存,但更新策略是先读取旧缓存显示出来,然后再更新。

      2.一个新页面使用已有的manifest文件(其他页面使用的,并且已经创建好缓存),初次访问时,会引起整个缓存更新吗?

在上一个测试的基础上,继续测试。

测试过程:

新建文件cache3.html,代码同cache.html;

访问cache3.html,查js版本号结果为“4”(最新文件的版本号);

修改m.js代码使版本号为“5”,刷新cache3.html,查看js版本号结果为“2”(缓存里的版本号);

测试结论:新页面使用旧manifest文件,初次访问时,不会造成旧缓存数据更新,并且加载的是实时加载线上资源的。再次访问时将使用旧缓存数据。

html5中manifest特性测试的更多相关文章

  1. HTML 5 应用程序缓存(Application Cache)cache manifest 文件使用 html5 中创建manifest缓存以及更新方法 一个manifest文件会创建一份缓存,不同的manifest文件其缓存的内容是互不干扰的

    HTML5 离线缓存-manifest简介 HTML 5 应用程序缓存 使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本. 什么是应用程序缓存(A ...

  2. HTML5中引入的关键特性

    新特性 描述 accesskey 定义通过键盘访问元素的快捷键 contenteditable 该特性设置为true时,浏览器应该允许用户编辑元素的内容.不指定变化后的内容如何保存 contextme ...

  3. HTML5 中的新特性:

    一,用于绘画的 canvas 元素,<canvas>标签替代Flash Flash给很多Web开发者带来了麻烦,要在网页上播放Flash需要一堆代码和插件.<canvas>标签 ...

  4. 测试开发之前端——No2.HTML5中的标签

    HTML5中的标签. 标签 描述 <!--...--> 定义注释. <!DOCTYPE>  定义文档类型. <a> 定义超链接. <abbr> 定义缩写 ...

  5. HTML5 中 40 个最重要的技术点

    介绍 我是一个ASP.NET MVC的开发者,最近在我找工作的时候被问到很多与HTML5相关的问题和新特性.所以以下40个重要的问题将帮助你复习HTML5相关的知识. 这些问题不是你得到工作的高效解决 ...

  6. HTML5中的DOMContentLoaded 和 touchmove

    Html5的出现确实解决了一部分页面交互的问题,同时它的一些特性还是没能被我们掌握,今天主要聊聊Html5中的DomcontenLoaded和touchmove事件的属性和使用: DomcontenL ...

  7. 小强的HTML5移动开发之路(2)——HTML5的新特性

    来自:http://blog.csdn.net/dawanganban/article/details/17592787 一.画布(Canvas) 画布是网页中的一块区域,可所以用JavaScript ...

  8. html5中script的async属性

    html5中script的async属性 我兴奋于html5的原因之一是一些久久未能实现的特性现在可以真正运用于实际项目中了. 如我们使用placeholder效果蛮久了但是那需要javascript ...

  9. 在HTML5中如何提高网站前端性能

    1.    用web storage替换cookiesCookie最大的问题是每次都会跟在请求后面.在HTML5中,用sessionStorage和localStorage把用户数据直接在客户端,这样 ...

随机推荐

  1. poj1328贪心 雷达,陆地,岛屿问题

    Radar Installation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 60381   Accepted: 13 ...

  2. MySQL之扩展(触发器,存储过程等)

    视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. SELECT * FROM ( SEL ...

  3. MFC 相关文件夹、文件操作

    //关于文件(夹)操作,可以参考下SHFileOperation这个外壳函数,貌似可以显示进度条.以下没有使用SHFileOperation//删除一个文件夹下的所有内容void myDeleteDi ...

  4. 【2016-07-11】Qt远程部署失败,提示"没有那个文件或目录"的解决方法

    首先明确一下,这里的部署失败与网络连接.ssh/scp/sftp等无关. 一般出现在删除了远端上的可执行文件,而本地程序未做明显改动时远程部署执行的时候. Qt应用程序输出中的提示信息如下: 究其原因 ...

  5. LESS学习笔记1

    个人理解:less是一个可以写函数的css

  6. windows 说“我爱你”

    CreateObject("SAPI.SpVoice").Speak "I love YOU" 保存vbs

  7. 引水入城(codevs 1066)

    题目描述 Description 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政 区划十分特殊,刚好构成一个N行M列的矩形,如上图所示,其中每个格子都代表一座城 市,每座 ...

  8. hrbustoj 1545:基础数据结构——顺序表(2)(数据结构,顺序表的实现及基本操作,入门题)

    基础数据结构——顺序表(2) Time Limit: 1000 MS    Memory Limit: 10240 K Total Submit: 355(143 users) Total Accep ...

  9. hdu 4267 多维树状数组

    题意:有一个序列 "1 a b k c" means adding c to each of Ai which satisfies a <= i <= b and (i ...

  10. C#学习笔记(一)——HelloWorld!

    一.平台的搭建(IDE) 使用的VS2013,不知道是不是微软--(省略N多字),注册只要简单的KEY,这个我们可以直接度娘一大堆,所以不用担心这个软件安不上去= = 建议使用2013社区版,官方免费 ...