jquery make div repeatedly fade in and out

11,018

The problem is recursively calling the fade*() routines from inside each other, you need to setup the sequence as something that can be called repeatedly in a non-recursive fashion.

This is quite a neat method:

Demo here: http://jsfiddle.net/ZZGhn/

$('.block').bind('fade-cycle', function() {
    $(this).fadeOut('fast', function() {
        $(this).fadeIn('fast', function() {
            $(this).trigger('fade-cycle');
        });
    });
});

// This next block of code just sets all the triggers off at random times
// The point is to start them using .trigger('fade-cycle');
// All can be started simultaneously with $('.block').trigger('fade-cycle');

$('.block').each(function(index, elem) {
    setTimeout(function() {
        $(elem).trigger('fade-cycle');
    }, index * 250);
});
Share:
11,018
Dizzy Bryan High
Author by

Dizzy Bryan High

Not much to say really, i love computers and love getting my hands dirty with code, i am by no means an expert, but i love learning new stuff. I work for base5 designs, a 2 person partnership i have with a friend of mine in London, I currently live in Berlin, Germany.

Updated on June 05, 2022

Comments

  • Dizzy Bryan High
    Dizzy Bryan High almost 2 years

    hello i have a series of divs created in a for loop like so:

    var myDiv ='#bannerHolder'
            var fib_str = '1, 2, 3, 5, 8, 13, 21, 1, 2, 3, 5, 8, 13, 21, 1, 2, 3, 5, 8, 13, 21, 1, 2, 3, 5, 8, 13'
            var widths_str = '33px, 31px, 35px, 9px, 16px, 50px, 33px, 24px, 40px, 20px, 63px, 30px, 10px, 29px, 11px, 12px, 51px, 31px, 35px, 11px, 14px, 50px, 30px, 25px, 38px, 20px, 35px'
            var pos_str = '0px, 44px, 105px, 144px, 153px, 203px, 236px, 269px, 280px, 354px, 374px, 437px, 447px, 457px, 506px, 517px, 529px, 604px, 646px, 687px, 698px, 712px, 762px, 787px, 823px, 895px, 915px'
            var color_str = '#D5E1D7, #18D4C9,#BF51C3,#1E82C9, #EDEDED, #E1C981, #C9A94F, #BDBCAA, #5DB522, #EB2F34, #823133, #004BD8, #A6A0A0, #DS9F36, #FFDB00, #69944F, #18D4C9, #BF51C3, #1E82C9, #6B949A, #FFDB00, #819E64, #BDBCAA, #54BA43, #EB2F34, #823133'
            var width = widths_str.split(",");
            var pos = pos_str.split(",");
            var color = color_str.split(",");
            var fib = fib_str.split(",");
            console.log(width);
            console.log(pos);
            console.log(color);
            var counter = width.length
            var stopper = false;
    for(i=0;i<counter;i++){
                    var html = '<div id ="stripe'+i+'"/>'   
                    $(myDiv).append(html)
                    $('#stripe'+i).css({  'top': 0,  'left': pos[i],'position': 'absolute', 'float': 'left', 'background-color' : color[i]})
                    $('#stripe'+i).attr({ 'min-width' : width[i], 'min-height' : '100px'  })
                    $('#stripe'+i).width(width[i])
                    $('#stripe'+i).height('100px')
    
    
                };
    

    what i want is to have each div created fade out completly then fade back in again and for this process to keep repeating for ever. if i try to use .animate() and call a function for the Complete: property i get too many recursions and the page breaks, how can i do this

  • trusktr
    trusktr over 12 years
    Nvm, I added a conditional to check if a variable is true before triggering each repeat.
  • Benjamin Gruenbaum
    Benjamin Gruenbaum over 11 years
    +1 for the interesting solution using event triggers, this can be done with CSS3 animations today but I liked the line of thought :)
  • Rick Burgess
    Rick Burgess over 10 years
    I know this old question but as far as stopping it goes you could also unbind the event trigger from .block, this would break the loop.
  • Orbling
    Orbling over 10 years
    @RickBurgess: Quite right, sensible method - that would finish after a fade-in part of the cycle.
  • Adrien Be
    Adrien Be almost 10 years
    using fadeTo("fast",0.01) instead of fadeOut() could avoid problems with the divs of being completely removed. see api.jquery.com/fadeto