手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >IE浏览器中图片onload事件无效的解决方法
IE浏览器中图片onload事件无效的解决方法
摘要:故事模式实现是只加载当前浏览的照片和它下面的两张照片,加载照片的时候才会加载和渲染评论区,图片没有加载前会用一个一象素的图片占位,并用一个l...

故事模式实现是只加载当前浏览的照片和它下面的两张照片,加载照片的时候才会加载和渲染评论区,图片没有加载前会用一个一象素的图片占位,并用一个loading类将显示出一个loading背景图,判断在可视区的时候替换成真正的图片,图片加载成功后删除loading类。

问题出在最后面,测试的时候发现在IE下loading类无法删除,当时代码如下:

复制代码 代码如下:

img.src = _src;

img.src = _src;

img.onload = function(){

_con.delClass('loading');

}

网上找了一番,onload和定义src的语句应该换一下顺序,IE从缓存中取图片,onload根本不触发,opera也有这个毛病,正确代码修改如下

复制代码 代码如下:

img.onload = function(){

_con.delClass('loading');

};

img.src = _src;

立即就正常了

结论:应该把onload写到src前面,先告诉浏览器图片加载完要怎么处理,再让它去加载图片。 所以,不是IE浏览器不会触发onload事件,而是因为加载缓冲区的速度太快,在没有告诉它加载完要怎么办时,它已经加载完了。反过来说,firefox明显更智能一些,加入onload事件后,firefox浏览器会检测缓冲区是否已经有此图片,有的话直接就触发此事件!

【IE浏览器中图片onload事件无效的解决方法】相关文章:

JavaScript获取两个数组交集的方法

在JavaScript中使用开平方根的sqrt()方法

JS实现简单路由器功能的方法

jQuery实现延迟跳转的方法

js验证上传图片的方法

Jquery注册事件实现方法

js去除浏览器默认底图的方法

会自动逐行上升的文本框

jquery预加载图片的方法

png在IE6 下无法透明的解决方法汇总

精品推荐
分类导航