问题
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?
回答1:
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; }
回答2:
You could have the fadeIn on element2 begin at the completion callback time of element1:
element1.fadeIn(500, function() {
element2.fadeIn(500, function() {
etc...
回答3:
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.
来源:https://stackoverflow.com/questions/3133316/fade-in-delay-on-load