开发者

why delaying chain functions causes problem?

开发者 https://www.devze.com 2023-02-22 22:36 出处:网络
var currentImage = 0; var images = new Array(\'Aerodynamics.jpg\',\'ABC_news.jpg\',\'yep.jpg\'); var newImage = \'url(images/\'+images[currentImage]+\')\';
var currentImage = 0;
var images = new Array('Aerodynamics.jpg','ABC_news.jpg','yep.jpg'); 
var newImage = 'url(images/'+images[currentImage]+')'; 

function slideSwitch() {
   $('.inner_img').css('background-image',newImage).animate({opacity:1.0},4000).delay(2000)
    .animate({opacity:0.0},4000,function(){
        if(currentImage < images.length-1){
            currentImage++;
        }else{
            currentImage = 0;  
        };
    });
};

First animation goes fine, delay() works fine too, next animation for opacity back to 0 doesn't works correctly, I mean the object hasn't disappear yet it already开发者_JAVA百科 triggers the callback function, please tell me what am I doing wrong


.animate() is non-blocking, meaning that the next step in your chain (the delay) starts immediately, not after the animation is done.

With jQuery 1.5's Deferred objects, you can force blocking behavior on animations, by creating a Deferred promise which is only resolved when the animation completes.

I answered a question which does exactly this yesterday, see my answer here for an example: Mouseover .animate stops prior .animate


You just need to attach the revert animation in an anonymous function.

function slideSwitch() {
   $('.inner_img').css('background-image',newImage)
        .animate({opacity:1.0},4000, function() {

           $(this).animate({opacity:0.0},4000,function(){
             if(currentImage < images.length-1){
               currentImage++;
             }else{
               currentImage = 0;  
            });
    });    
};
0

精彩评论

暂无评论...
验证码 换一张
取 消