浴火重生

雄关漫道真如铁,而今迈步从头越

目标: 1+1=2

导航

IE图片缓存测试

经常我们会用js动态创建html元素。但是最近的项目中发现IE浏览器每次都要重新加载页面的所有图片,所以根据一篇博文测试这个问题。

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试ajax引起图片下载的问题</title>
</head>

<body>
</body>
<script type="text/javascript">
<!--
var st="<img name=\"img1\" src=\"http://space.cnblogs.com/images/logo.gif\">"
var ar = new Array(101);
window.onload=function(){
    document.body.innerHTML = ar.join(st);
}
</script>
</html>

以上页面代码就会引起所有img元素重新从服务器加载图片。 分析以后,觉得先让浏览器生成img的dom对象,然后更改属性。所以进行修改如下:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试ajax引起图片下载的问题</title>
</head>

<body>
</body>
<script type="text/javascript">
<!--
var st="<img name=\"img1\" src=\"\">"
var ar = new Array(101);
window.onload=function(){
    document.body.innerHTML = ar.join(st);
 var obj = document.getElementsByTagName("img");
            for(var i = 0;i < obj.length; i++){
    obj[i].src = "http://space.cnblogs.com/images/logo.gif";       
            }
}
</script>
</html>

发现,以上代码依然会引起所有img元素重新从服务器下载图片。 最后把代码执行时机进行改变,修改代码:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试ajax引起图片下载的问题</title>
</head>

<body>
</body>
<script type="text/javascript">
<!--
var st="<img name=\"img1\" src=\"http://space.cnblogs.com/images/logo.gif\">"
var ar = new Array(101);
document.body.innerHTML = ar.join(st);
</script>
</html>

发现所有img从服务器重新请求的问题已经解决。代码改成以下情况也一样:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试ajax引起图片下载的问题</title>
</head>

<body>
</body>
<script type="text/javascript">
<!--
var st="<img name=\"img1\" src=\"\">"
var ar = new Array(101);
document.body.innerHTML = ar.join(st);
 var obj = document.getElementsByTagName("img");
    for(var i = 0;i < obj.length; i++){
    obj[i].src = "http://space.cnblogs.com/images/logo.gif";       
            }
</script>
</html>

也不存在所有img重新下载图片的情况。 因此,看来是页面上js构造html元素的时机将引起IE浏览器对图片的缓存策略的问题。使用ajax请求数据,动态构建UI的时候,
这个问题一定要注意。


posted on 2009-09-08 15:41  浴火重生  阅读(424)  评论(1编辑  收藏  举报