概述
在IE中,如果新建一个image对象,然后添加onload事件加载一个GIF动画图片时,onload执行方法会重复执行,而在除IE外的浏览器就没有这个问题。
<
script type
=
"
text/javascript
"
>
var img = new Image();
img.src = " test.gif " ;
img.onload = function (){
alert( " 这里会重复弹出! " );
}
< / script>
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>
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
最后
以上就是忧心裙子为你收集整理的IE处理GIF动画图片onload事件的一个BUG的全部内容,希望文章能够帮你解决IE处理GIF动画图片onload事件的一个BUG所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复