The HTML ontransitionstart event
The HTML ontransitionstart attribute runs JavaScript when a CSS transition actually starts (after any delay). It is an inline handler for the transitionstart event; in modern code prefer addEventListener('transitionstart', …).
Overview
The ontransitionstart event attribute runs JavaScript when a CSS transition starts. In JavaScript the event itself is named transitionstart — drop the on prefix when you call addEventListener.
It is a CSS transition event. The handler receives a TransitionEvent with the propertyName that transitioned, which is the clean way to chain an action after a CSS transition completes.
You can wire this up with the inline ontransitionstart HTML attribute, but the modern, recommended approach is element.addEventListener('transitionstart', handler) in JavaScript. That keeps behavior out of your markup, lets you attach several handlers to the same event, and makes them easy to remove. The inline attribute is fine for quick demos.
Syntax
<element ontransitionstart="handler()">…</element>
element.addEventListener('transitionstart', handler);
Best practices
- Prefer
element.addEventListener('transitionstart', handler)over the inlineontransitionstartattribute — it separates behavior from markup and allows multiple handlers. - Use it to run code after a CSS transition instead of guessing with a timer.
- Check
event.propertyNamewhen several properties transition at once. - Respect
prefers-reduced-motionfor the transitions these events track.
Frequently asked questions
What is the ontransitionstart event?
transitionstart.How do I run code after a CSS transition ends?
Which property finished transitioning?
event.propertyName from the TransitionEvent.Should I use the ontransitionstart attribute or addEventListener?
addEventListener('transitionstart', …) in JavaScript. The inline ontransitionstart attribute works but mixes behavior into the markup and allows only one handler per element.