docs.rodeo

MDN Web Docs mirror

Element: transitionstart event

{{APIRef}} 

The transitionstart event is fired when a CSS transition has actually started, i.e., after any {{cssxref("transition-delay")}}  has ended.

This event is not cancelable.

Syntax

Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}} , or set an event handler property.

addEventListener("transitionstart", (event) => { })

ontransitionstart = (event) => { }

Event type

A {{domxref("TransitionEvent")}} . Inherits from {{domxref("Event")}} .

{{InheritanceDiagram("TransitionEvent")}} 

Event properties

Also inherits properties from its parent {{domxref("Event")}} .

Examples

This code adds a listener to the transitionstart event:

element.addEventListener("transitionstart", () => {
  console.log("Started transitioning");
});

The same, but using the ontransitionstart property instead of addEventListener():

element.ontransitionstart = () => {
  console.log("Started transitioning");
};

Live example

In the following example, we have a simple {{htmlelement("div")}}  element, styled with a transition that includes a delay:

<div class="transition">Hover over me</div>
<div class="message"></div>
.transition {
  width: 100px;
  height: 100px;
  background: red;
  transition-property: transform, background;
  transition-duration: 2s;
  transition-delay: 1s;
}

.transition:hover {
  transform: rotate(90deg);
  background: transparent;
}

To this, we’ll add some JavaScript to indicate where the transitionstart and {{domxref("Element/transitionrun_event", "transitionrun")}}  events fire.

const transition = document.querySelector(".transition");
const message = document.querySelector(".message");

transition.addEventListener("transitionrun", () => {
  message.textContent = "transitionrun fired";
});

transition.addEventListener("transitionstart", () => {
  message.textContent = "transitionstart fired";
});

transition.addEventListener("transitionend", () => {
  message.textContent = "transitionend fired";
});

{{ EmbedLiveSample('Live example', '100%', '170') }} 

The difference is that:

Specifications

{{Specifications}} 

Browser compatibility

{{Compat}} 

See also

In this article

View on MDN