Smooth image fade out, change src, and fade in with jquery

徘徊边缘 提交于 2019-11-27 02:15:54

问题


I am trying to do the following:

On link click:

1.) fade out an img

2.) change the src of the now hidden image

3.) when the img with the new src finishes loading, fade in

Minimally, I'd like to see a smooth fade out of one image and a fade in of another (within the same img tag by changing the src)

Eventually I'd like to:

1.) fade out an img

2.) show a animated gif "loading image"

3.) change the src of the now hidden image

4.) hide the animated gif "loading image"

5.) when the img with the new src finishes loading, fade in

Thanks.

This is what I tried so far. It seems to do a couple flashes but only after the src changes (prior to the fade out). Strange behavior.

$("#Image").fadeOut();
$("#Image").attr("src", NEW_IMAGE_SRC);
$("#Image").fadeIn();

#Image is an IMG tag


回答1:


Try this:

$('.click').click(function() {
   $('img.class').fadeOut(300, function(){
      $(this).attr('src','new_src.png').bind('onreadystatechange load', function(){
         if (this.complete) $(this).fadeIn(300);
      });
   });
});


来源:https://stackoverflow.com/questions/9959926/smooth-image-fade-out-change-src-and-fade-in-with-jquery

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!