docs.rodeo

MDN Web Docs mirror

Element: transitionrun event

{{APIRef}} 

The transitionrun event is fired when a CSS transition is first created, i.e., before any {{cssxref("transition-delay")}}  has begun.

This event is not cancelable.

Syntax

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

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

ontransitionrun = (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 transitionrun event:

el.addEventListener("transitionrun", () => {
  console.log(
    "Transition is running but hasn't necessarily started transitioning yet",
  );
});

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

el.ontransitionrun = () => {
  console.log(
    "Transition started running, and will start transitioning when the transition delay has expired",
  );
};

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 {{domxref("Element/transitionstart_event", "transitionstart")}}  and transitionrun events fire.

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

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

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

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

{{ EmbedLiveSample('Live_example', '100%', '150px') }} 

The difference is that:

The transitionrun will occur even if the transition is canceled before the delay expires. If there is no transition delay or if transition-delay is negative, both transitionrun and transitionstart are fired.

Specifications

{{Specifications}} 

Browser compatibility

{{Compat}} 

See also

In this article

View on MDN