IE处理GIF动画图片onload事件的一个BUG

在IE中,如果新建一个image对象,然后添加onload事件加载一个GIF动画图片时,onload执行方法会重复执行,而在除IE外的浏览器就没有这个问题。

 

 
  
< script type = " text/javascript " >
var img = new Image();
img.src
= " test.gif " ;
img.onload
= function (){
alert(
" 这里会重复弹出! " );
}
< / script>

 

经过研究发现,出现这种原因是因为GIF动画里有多个帧,每个帧都会触发一次onload事件,所以会一直执行onload的方法,知道了病因解决起来就简单了。

 
  
< script type = " text/javascript " >
var img = new Image();
img.src
= " test.gif " ;
img.onload
= function (){
alert(
" 加载完成,只弹一次 " );
img.onload
= null ; // 关键点就是这了
}
< / script>

 

加载完成后要把onload事件赋为null,这样img动画到下一帧时就没有onload事件可触发了。

转载于:https://www.cnblogs.com/Lewis/archive/2011/01/17/1937066.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值