meizz的专栏

梅花雪·疏影横斜

原创 IE6的BUG:window.onload里用innerHTML创建的img会忽略本地缓存收藏

新一篇: 一段判断多种浏览器类型及版本号的脚本代码

  今天遇到这么一个问题,IE6,在window.onload里用innerHTML动态插入图片,结果这些图片都忽略了本地缓存策略,发出N多个304请求。

  于是乎我换了一个写法,在innerHTML里不使用img,而是在innerHTML新添加的HTML标签中使用CSS样式来导入图片,但问题依旧,IE6 还是狂发304请求。

  在网上搜索到了emu一篇BLOG说innerHTML创建的 img 都会忽略本地缓存,示例代码如下。那原因真的就是 innerHTML 创建的 img 忽略缓存吗?未必!


<html>
<body>
    
<div id="dd"></div>
</body>

<script type="text/javascript">
var a = new Array(101);
var s = "<img alt='' src='http://www.baidu.com/img/logo.gif' /><br/>";

window.onload 
= function()
{
    document.getElementById(
"dd").innerHTML = a.join(s);
}

</script>
</html>


运行上述代码,监控HTTP请求时确实是在狂发304请求,但是我的 MzTreeView 里也是使用 innerHTML 大量创建 <img> 也没有发现本地缓存失效,所以根本原因并不在 innerHTML 上,而是在 window.onload 里。同样的代码改成如下代码再运行试试:

 

<html>
<body>
  
<div id="dd"></div>
</body>

<script type="text/javascript">
var a = new Array(101);
var s = "<img alt='' src='http://www.baidu.com/img/logo.gif' /><br/>";
document.getElementById(
"dd").innerHTML = a.join(s);
</script>
</html>

 

再用HTTP请求监控软件看看!

IE6里确实存在动态创建的 img 忽略本地缓存的BUG,但是这个BUG不是出在 innerHTML 上而是在 window.onload 这个事件里。这个BUG在IE7里已经解决了。

BUG的修正方案:
  一是象上面的例子里那样把脚本放到后面直接运行;
  二是在 window.onload 里再用 setTimeout 延迟执行。

发表于 @ 2007年10月08日 19:20:00|评论(loading...)|编辑

旧一篇: 对几个 javascript framework 的评价

评论

#freeaccept 发表于2007-10-10 10:58:35  IP: 124.42.78.*
梅子好久没更新blog了~
#rczjp 发表于2007-10-10 14:33:14  IP: 219.137.43.*
传说中的高手,留言一个...
#rczjp 发表于2007-10-10 14:34:48  IP: 219.137.43.*
请问一下,为什么101却只有100个图片啊
#rczjp 发表于2007-10-10 14:53:34  IP: 219.137.43.*
我的是IE6可以显示啊??
#eye_of_back 发表于2007-10-11 00:35:37  IP: 123.119.79.*
这说明如果脚本与页面加载一起执行,则启用缓存机制,而如果页面加载完毕后再执行脚本,则不启用缓存机制,的确是应该改进了。
#wjfunion 发表于2007-10-11 13:27:29  IP: 221.221.167.*
fdsafsadfsad
#shanhe 发表于2007-10-14 18:29:00  IP: 59.42.44.*
你知道304是什么意思吗?喊什么 Bug!搞懂再说吧
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © meizz