Home >Web Front-end >CSS Tutorial >How Can I Efficiently Create Staggered CSS Animations for Multiple Child Elements?
CSS Animations with Staggered Delays for Child Elements
You're aiming to create a cascading effect where each child element in an element animates with a delay. To achieve this, you have been manually setting the animation delay for each child individually, as seen in your code snippet. However, you're seeking a more efficient solution for dynamically applying delays based on the number of child elements.
A CSS solution using a Sass for loop offers a concise and scalable approach to this problem:
@for $i from 1 through 10 { .myClass img:nth-child(#{$i}n) { animation-delay: #{$i * 0.5}s; } }
This loop iterates from 1 to 10 (adjustable to accommodate the expected number of child elements) and assigns a calculated delay value to each child using the nth-child selector. The delay is computed by multiplying the child's index ($i) by a desired delay period (0.5 seconds in this example).
By using this loop, you can apply cascading delays to any number of child elements without manually writing out individual styles. This solution eliminates the need to explicitly specify styles for each child and ensures consistency across all elements.
The above is the detailed content of How Can I Efficiently Create Staggered CSS Animations for Multiple Child Elements?. For more information, please follow other related articles on the PHP Chinese website!