curly_brackets
curly_brackets

Reputation: 5598

Fade in delay on Load

I've stumpled on something quite nice, I've wanted to use in some upcoming project.

It's an animated opacity on load, or you can call it fade in.

I wondered if you could link some elements together (ex. 3) so element2 only starts when element1 is finished, and element3 when no. 2 is?

Or should you define a delay on element2 and multiply the delay on element3?

Upvotes: 4

Views: 14114

Answers (3)

Nick Craver
Nick Craver

Reputation: 630627

If you had divs, say class="faded", you could fade each in on load, each in a row like this:

$(".faded").each(function(i) {
  $(this).delay(i * 400).fadeIn();
});

You can view a demo of this effect here, or a slower version here. The 400 is for 400ms, the duration of the normal .fadeIn() speed :)

You can either use .hide() to hide them on page load, like this:

$(".faded").hide()

Or do it in the CSS:

.faded { display: none; }

Upvotes: 12

andyortlieb
andyortlieb

Reputation: 2416

Since I don't believe that these types of animation have anything in the way of a success callback, if you know how long an element will take to fade, you can use something like setTimeout() to fire off the next after the proper amount of time has passed.

Edit: I stand corrected.

Upvotes: -1

Joey C.
Joey C.

Reputation: 2386

You could have the fadeIn on element2 begin at the completion callback time of element1:

 element1.fadeIn(500, function() {  
       element2.fadeIn(500, function() { 
            etc...

Upvotes: 4

Related Questions