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.οnlοad=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.οnlοad=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的时候,
这个问题一定要注意。


转载于:https://www.cnblogs.com/habit/archive/2009/09/08/1562598.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值