ie6里window.onload用innerHTML忽略本地缓存的问题

dandelionl 2008-08-25 12:33:57
<html>
<body>
<div id="dd"></div>
</body>

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

只是把脚本代码延后直接运行就没有了这个BUG。 meizz 的方法


■■问题是我的 window.onload 如何改呢?!■■

----------js:
var s_obj;
function $(name) {return document.getElementById(name);}

function show(e)
{
e = window.event ¦ ¦ e;
s_obj.style.display = "block";
if (this.getAttribute("imageu")){s_obj.innerHTML = ' <img src="' + this.getAttribute("imageu") + '" left:0px;align=left>';}
s_obj.style.left = e.clientX + 10+ document.body.scrollLeft - document.body.clientLeft;
s_obj.style.top = e.clientY + 10+ document.body.scrollTop - document.body.clientTop;
}

function clearshow() {s_obj.style.display = "none";}

window.onload = function ()
{var a = document.getElementsByTagName("a");
for (var i = 0; i < a.length; i ++) {a[i].onmousemove = show;a[i].onmouseout = clearshow; }
s_obj = $("mytips");

------css:.s{event:expression(
onmouseover = function(){this.style.backgroundColor='#55B8E6'},
onmouseout = function(){this.style.backgroundColor='#FFFFFF'}
)

------body
<tr> <td class= "s"> <a href="#" imageu="a2350030.jpg">名字 </a> </td>

<div id=mytips style="position:absolute;
Z-INDEX: 2;
width:5;
display:none;
border:1 solid;
background-color:#ffffff;">
</div>

</body>
...全文
394 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
dandelionl 2008-08-25
  • 打赏
  • 举报
回复
meizz 的文章:

今天遇到这么一个问题,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 延迟执行。


■■但是我实在找不出window.onload脚本能放在什么地方,放了也不对■■
直接把----------js: 去掉window.onload,其余代码放在
<body>之间</body>之后都不行

87,923

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧