您现在的位置:首页 --> JavaScript --> IE中Image .onload方法问题
IE中Image .onload方法问题
浏览:1381次 出处信息
在web开发在获取图片宽高是很正常的事情,图片在加载完成前是获取不到图片的宽高的,在加载完成后才可以获取图片本身的宽高,例如:
1 |
var img = new Image(); |
2 |
img.src = "loading.gif"; |
3 |
img.onload = function(){ |
4 |
alert ( img.width ); |
5 |
}; |
OK?这段代码看着没什么问题,但在ie中会有一个bug,就是ie第一次打开的时候没问题,第二次使用这个方法就悲剧了,ie没反应了,即使刷新页面也是一样。因为IE会缓存图片,第2次加载的图片,不是从服务器上传过来的,而是从缓冲区里加载的。
先写onload方法,再指定这张图片的URL,这样就正常了。所以,不是IE没有触发onload事件,而是因为加载缓冲区的速度太快,以至于没有运行到img.onload的时候,onload事件已经触发了。这样就OK了。
1 |
var img = new Image(); |
2 |
img.onload = function(){ |
3 |
alert ( img.width ); |
4 |
}; |
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:如何判断Javascript对象是否存在
后一篇:JS文件加载失败处理 >>
文章信息
- 作者:愚人码头 来源: WEB前端开发
- 标签: onload
- 发布时间:2011-05-15 14:35:32
近3天十大热文
-
[903] WordPress插件开发 -- 在插件使用 -
[135] 解决 nginx 反向代理网页首尾出现神秘字 -
[56] 整理了一份招PHP高级工程师的面试题 -
[54] Innodb分表太多或者表分区太多,会导致内 -
[54] 如何保证一个程序在单台服务器上只有唯一实例( -
[52] 全站换域名时利用nginx和javascri -
[52] 海量小文件存储 -
[52] CloudSMS:免费匿名的云短信 -
[51] 用 Jquery 模拟 select -
[49] ps 命令常见用法