Transitions & Animation
Transition Delay
Utilities for controlling the delay of CSS transitions.
Quick reference
Class | Properties |
---|---|
delay-0 | transition-delay: 0s; |
delay-75 | transition-delay: 75ms; |
delay-100 | transition-delay: 100ms; |
delay-150 | transition-delay: 150ms; |
delay-200 | transition-delay: 200ms; |
delay-300 | transition-delay: 300ms; |
delay-500 | transition-delay: 500ms; |
delay-700 | transition-delay: 700ms; |
delay-1000 | transition-delay: 1000ms; |
Basic usage
Delaying transitions
Use the delay-{amount}
utilities to control an element’s transition-delay.
Hover each button to see the expected behaviour
<button class="transition delay-150 duration-300 ease-in-out ...">Button A</button>
<button class="transition delay-300 duration-300 ease-in-out ...">Button B</button>
<button class="transition delay-700 duration-300 ease-in-out ...">Button C</button>
Applying conditionally
Hover, focus, and other states
Tailwind lets you conditionally apply utility classes in different states using variant modifiers. For example, use hover:delay-300
to only apply the delay-300
utility on hover.
<div class="transition duration-300 delay-150 hover:delay-300">
<!-- ... -->
</div>
For a complete list of all available state modifiers, check out the Hover, Focus, & Other States documentation.
Breakpoints and media queries
You can also use variant modifiers to target media queries like responsive breakpoints, dark mode, prefers-reduced-motion, and more. For example, use md:delay-300
to apply the delay-300
utility at only medium screen sizes and above.
<div class="transition duration-300 delay-150 md:delay-300">
<!-- ... -->
</div>
To learn more, check out the documentation on Responsive Design, Dark Mode and other media query modifiers.
Using custom values
Customizing your theme
By default, Tailwind provides eight general purpose transition-delay utilities. You can customize these values by editing theme.transitionDelay
or theme.extend.transitionDelay
in your tailwind.config.js
file.
tailwind.config.js
module.exports = {
theme: {
extend: {
transitionDelay: {
'2000': '2000ms',
}
}
}
}
Learn more about customizing the default theme in the theme customization documentation.
Arbitrary values
If you need to use a one-off transition-delay
value that doesn’t make sense to include in your theme, use square brackets to generate a property on the fly using any arbitrary value.
<div class="delay-[2000ms]">
<!-- ... -->
</div>
Learn more about arbitrary value support in the arbitrary values documentation.