Skip to main content
Home / CSS Almanac / Properties / T / transition-delay


The transition-delay property, normally used as part of transition shorthand, is used to define a length of time to delay the start of a transition.

.example {
    transition-delay: 5s;

The value can be one of the following:

  • A valid time value (defined in seconds or milliseconds)
  • A comma-separated list of time values, for defining separate delay values on multiple transitions for a single element

The default value for transition-delay is 0s, meaning that no delay will take place and the transition will start to occur immediately. The time value can be expressed as a decimal-based number for more precise timing.

When a transition has a delay value that is negative, it will cause the transition to begin immediately (with no delay), however the transition will begin partway through the process, as though it had already begun.

The following CodePen shows a hover effect on a box that uses a transition-delay value of 2s with a transition duration of 1s:

Check out this Pen!

Now compare that to the following demo, which has a delay of -1s and a duration of 3s:

Check out this Pen!

Notice that in the second example, only the final two-thirds of the actual transition are visible and there is no delay. The negative value removes the delay and effectively cuts into the duration.

For compatibility in all supporting browsers, vendor prefixes are required, with the standard syntax declared last:

.example {
    -webkit-transition-delay: 500ms;
    -moz-transition-delay: 500ms;
    -o-transition-delay: 500ms;
    transition-delay: 500ms;

IE10 (the first stable version of IE to support transition-delay) does not require the -ms- prefix.

Related Properties

Other Resources

Browser Support

Chrome Safari Firefox Opera IE Android iOS
Works Works 4+ 10.5+ 10+ 2.1+ 3.2+
icon-link icon-logo-star icon-search icon-star